如何池化.NET内存流以解决大内存堆分配问题

发布时间:2021-12-06 14:29:40 作者:柒染
来源:亿速云 阅读:128

这篇文章给大家介绍如何池化.NET内存流以解决大内存堆分配问题,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

与很多依赖于标记-清理的垃圾回收器的语言一样,C#也会在频繁分配内存或分配大块内存时产生性能问题。微软必应的高级软件开发工程师Ben Watson,就曾在使用MemoryStream类的时候遇到了这种问题。在他的Writing High-Performance .NET Code一书中,他写道,

在某个饱受大量LOH(大对象堆)分配之苦的应用中,我们发现如果将某种类型的对象保存在池中,就能解决99%的LOH问题。这个对象就是我们在网络中序列化和传输位的MemoryStream。为了避免碎片,我们保存了一个MemoryStream对象的队列,尽管实际实现要复杂得多,但理论上来说基本如此。每次MemoryStram对象释放的时候,就将其放回池中以供复用。

在此之后微软将他的代码放到了Microsoft.IO.RecycableMemoryStream类中。该类是传统的内存流的代替品。在最简单的情况下,可以用manager.GetStream代替new MemoryStream

注意这个流管理器是线程安全的,并且应该在进程中一直使用。

《华盛顿邮报》作者Ben Watson说,这个工具被优化后要执行如下部分:

关于如何池化.NET内存流以解决大内存堆分配问题就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. Python内存分配
  2. C语言中内存分配问题

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

上一篇:ASP.NET Core的Middleware怎么使用

下一篇:Hyperledger Fabric如何实现Fabric源码本地调试

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》