【BeetleX重构】构建更节省应用内存的对象池
💡
原文中文,约1900字,阅读约需5分钟。
📝
内容提要
.NET框架提供了一些对象池,但有时需要自己编写简单的对象池。最近在优化BeetleX时发现一种更好的Lock使用方式,通过ArrayPool<T>的代码发现内部实现是使用LOCK+数据组来实现高效的线程安全Stack结构。测试结果显示,分区Stack和ConcurrentStack的性能基本一致,但内存占用有巨大差异。
🎯
关键要点
-
.NET框架提供了一些对象池,但有时需要自己编写简单的对象池。
-
编写对象池时需要考虑线程安全,通常使用非线程安全结构和加锁或System.Collections.Concurrent。
-
System.Collections.Concurrent使用轻量的自旋锁处理并发问题,性能优于传统Lock方式。
-
在优化BeetleX时发现另一种Lock使用方式,通过LOCK+数据组实现高效线程安全Stack结构。
-
ArrayPool<T>的实现没有使用.Net自带的Stack和ConcurrentStack,而是通过Lock和特别设计解决Lock引发的性能问题。
-
BeetleX内部对象使用分区Stack和ConcurrentStack,性能基本一致但内存占用差异巨大。
-
ConcurrentStack在高并发时产生较多内存开销,而分区Stack内存开销平稳。
🏷️
标签
➡️