博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
池化.NET内存流以解决大内存堆分配问题
阅读量:6241 次
发布时间:2019-06-22

本文共 428 字,大约阅读时间需要 1 分钟。

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

\\
\

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

\
\\

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

\\

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

\\

查看英文原文

转载地址:http://ardia.baihongyu.com/

你可能感兴趣的文章
互联网组织的未来:剖析 GitHub 员工的任性之源
查看>>
Java 开源博客 Solo 1.4.0 发布 - 简化
查看>>
Oracle巡检
查看>>
【转载】胜者树
查看>>
查看mysql数据库存放的路径|Linux下查看MySQL的安装路径
查看>>
selenium+testNG+Ant
查看>>
1024程序员节,你屯书了吗?(内含福利)
查看>>
移动端JS 触摸事件基础
查看>>
Flex拖动原来如此简单
查看>>
温故而知新:什么是wcf
查看>>
centos语言设置
查看>>
php安装
查看>>
Fragment在getUserVisibleHint时进行加载数据的问题记录
查看>>
使用线程池模拟处理耗时任务,通过websocket提高用户体验
查看>>
Java 内部类种类及使用解析
查看>>
Axure产品原型设计工具
查看>>
spice在桌面虚拟化中的应用系列之三(USB映射实现,SSL加密,密码认证,多客户端支持)...
查看>>
Loading project 91606170 of 1: Project FooBar 问题如何解决?
查看>>
C# yeild使用
查看>>
MapReduce-Hadoop分布式计算模型
查看>>