写点什么

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

  • 2015-03-29
  • 本文字数:414 字

    阅读完需:约 1 分钟

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

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

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

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

查看英文原文 Pooled Memory Streams for .NET

2015-03-29 08:564636
用户头像

发布了 59 篇内容, 共 24.0 次阅读, 收获喜欢 3 次。

关注

评论

发布
暂无评论
发现更多内容

经济金融的数字化转型并没有消除风险,风险反而更加复杂

CECBC

Kubernetes手记(11)- 配置信息容器化

雪雷

k8s 6月日更

SpringCloud Gateway 动态路由

黄仲辉

mongodb 响应式编程 源码阅读 动态路由 SpringCloud Gateway

物联网平台规则引擎流转到S3对比

张俭

azure IoT AWS 华为云

浏览器上有趣的Console命令都了解吗?

空城机

大前端 浏览器 6月日更

算法训练营 - 学习笔记 - 第十周

心在飞

Trello个人生产力简易指南

俞凡

生产力 认知 大厂实践

【FlinkSQL】Flink SQL Query 语法(四)- Rattern Recognition

Alex🐒

flink 翻译 FlinkSQL flink1.13

色情,科技,与女性

脑极体

【LeetCode】猜数字大小Java题解

Albert

算法 LeetCode 6月日更

springboot启动流程之加载入口类

梦倚栏杆

数字化转型的征途

CECBC

《原则》(十四)

Changing Lin

6月日更

架構實戰營 - 模塊 5 作業

Frank Yang

架构实战营

LeetCode 每日一题「接雨水」

陈皮的JavaLib

Java LeetCode 动态规划

小团队真的适合引入SpringCloud微服务吗?

xcbeyond

微服务 6月日更

回归分析

Qien Z.

6月日更 回归分析

算法训练营 - 知识总结

心在飞

架构实战营 - 模块6 - 作业

笑春风

假如我是创业公司CEO之电商小程序微服务拆分

ifc177

面试官嘲笑我,这你都不会?

李阿柯

php 面试 redis cluster

Pandas高级教程之:Dataframe的合并

程序那些事

Python 数据分析 pandas 程序那些事 数据分析研究

Python——列表切片

在即

6月日更

前端 CSS 变量简介及基本使用方法

编程三昧

CSS css3 大前端 样式

实现一个执行Explain 命令的Mybatis 插件

water

视频号真人首播 - 踩坑经验总结

悟空聊架构

复盘 直播 视频号 6月日更

算法之异位词字符处理

Skysper

算法

标杆管理:让自己快速成长的实用工具

石云升

创业 职场经验 6月日更

MySQL基础之十二:增删改

打工人!

myslq 6月日更

架构实战训练营 - 模块五课后作业

Johnny

架构实战营

「SQL数据分析系列」3. 查询入门

Databri_AI

MySQL select

池化.NET内存流以解决大内存堆分配问题_.NET_Jonathan Allen_InfoQ精选文章