如果不停的 new 数组,可能会造成 GC 的压力,因此在 aspnetcore 中推荐使用 ArrayPool 来重用数组,本文将介绍如何使用 ArrayPool。

使用 ArrayPool

ArrayPool 是一个静态类,它提供了一个共享的数组池,可以用来重用数组。它可以用来避免频繁的分配和回收数组,从而减少 GC 的压力。

ArrayPool 的使用非常简单,只需要调用它的静态方法 Rent 即可。Rent 方法有两个参数,第一个参数是数组的长度,第二个参数是数组的最小长度。如果你不知道数组的最小长度,可以传递一个默认值,比如 16。下面是一个使用 ArrayPool 的 C# 示例:

using System;
using System.Buffers; class Program
{
static void Main(string[] args)
{
// 创建一个数组池
var pool = ArrayPool<int>.Shared; // 从池中获取一个长度为 10 的数组
int[] array = pool.Rent(10);
try
{
// 在数组中填充一些数据
for (int i = 0; i < array.Length; i++)
{
array[i] = i;
} // 使用数组中的数据
foreach (int i in array)
{
Console.WriteLine(i);
}
}
finally
{
// 将数组归还到池中
pool.Return(array);
}
}
}

在上面的示例中,我们首先通过调用 ArrayPool.Shared 来获取一个数组池的实例。接下来,我们通过调用 pool.Rent(10) 方法从池中获取一个长度为 10 的整数数组。在数组中填充数据后,我们遍历数组并输出其中的元素。最后,我们通过调用 pool.Return(array) 方法将数组归还到池中。

需要注意的是,在使用完数组后,必须将其归还到池中,否则该数组将一直占用池中的内存,导致内存泄漏。

使用场景

一个典型的场景是在高吞吐量的网络应用程序中,例如 Web 服务器或消息队列服务器中。这些服务器需要处理大量的网络请求或消息,这些请求或消息可能涉及到大量的内存分配和释放。如果在每个请求或消息处理期间都需要分配和释放内存,那么垃圾回收器将面临重大的压力,导致系统性能下降。

使用 ArrayPool 可以通过池化内存缓解这种情况。这样,当需要分配数组时,可以从池中获取可用的数组而不是分配新的数组,从而减少垃圾回收的压力。一旦使用完毕,将数组返回到池中,以便可以重复使用。

例如,一个 HTTP 服务器可能需要同时处理多个客户端请求,每个请求都需要读取和处理请求正文。在这种情况下,可以使用 ArrayPool 来池化内存,以便在每个请求处理期间重复使用相同的缓冲区。这将减少内存分配和垃圾回收的开销,从而提高服务器的性能和吞吐量。

总结

ArrayPool 是一个静态类,它提供了一个共享的数组池,可以用来重用数组。它可以用来避免频繁的分配和回收数组,从而减少 GC 的压力。

参考

感谢阅读,如果觉得本文有用,不妨点击推荐或者在评论区留下 Mark,让更多的人可以看到。

欢迎关注作者的微信公众号“newbe技术专栏”,获取更多技术内容。


  1. https://learn.microsoft.com/dotnet/api/system.buffers.arraypool-1?view=net-7.0&WT.mc_id=DX-MVP-5003606

如何使用 ArrayPool的更多相关文章

  1. 数组(ArrayPool数组池、Span<T>结构)

    前言 如果需要使用相同的类型的多个对象,就可以使用集合和数组,这一节主要讲解数组,其中会重点涉及到Span<T>结构和ArrayPool数组池.我们也会先涉及到简单的数组.多维数组.锯齿数 ...

  2. 使用ArrayPool池化大型数组(翻译)

    原文链接:https://adamsitnik.com/Array-Pool/ 使用ArrayPool 简介 .NET的垃圾收集器(GC)实现了许多性能优化,其中之一就是,设定年轻的对象很快消亡,然而 ...

  3. ArrayPool数组池、Span<T>结构

    数组(ArrayPool数组池.Span<T>结构) 目录 前言 简单的数组.多维数组.锯齿数组 Array类 ArrayPool数组池 Span Span介绍 Span切片 使用Span ...

  4. 如何在 C# 中使用 ArrayPool 和 MemoryPool

    对资源的可复用是提升应用程序性能的一个非常重要的手段,比如本篇要分享的 ArrayPool 和 MemoryPool,它们就有效的减少了内存使用和对GC的压力,从而提升应用程序性能. 什么是 Arra ...

  5. ArrayPool 源码解读之 byte[] 也能池化?

    一:背景 1. 讲故事 最近在分析一个 dump 的过程中发现其在 gen2 和 LOH 上有不少size较大的free,仔细看了下,这些free生前大多都是模板引擎生成的html片段的byte[]数 ...

  6. C# ArrayPool 源码解读之 byte[] 池化

    一:背景 1. 讲故事最近在分析一个 dump 的过程中发现其在 gen2 和 LOH 上有不少size较大的free,仔细看了下,这些free生前大多都是模板引擎生成的html片段的byte[]数组 ...

  7. .Net性能调优-ArrayPool

    定义 高性能托管数组缓冲池,可重复使用,用租用空间的方式代替重新分配数组空间的行为 好处 可以在频繁创建和销毁数组的情况下提高性能,减少垃圾回收器的压力 使用 获取缓冲池实例:Create/Share ...

  8. .NET性能优化-ArrayPool同时复用数组和对象

    前两天在微信后台收到了读者的私信,问了一个这样的问题,由于私信回复有字数和篇幅限制,我在这里统一回复一下.读者的问题是这样的: 大佬您好,之前读了您的文章受益匪浅,我们有一个项目经常占用 7-8GB ...

  9. The week in .NET - 1/12/2015

    On.NET Last week, we had Mads Torgersen on the show to talk about language design in general, and C# ...

  10. nginx学习七 高级数据结构之动态数组ngx_array_t

    1 ngx_array_t结构 ngx_array_t是nginx内部使用的数组结构.nginx的数组结构在存储上与大家认知的C语言内置的数组有相似性.比方实际上存储数据的区域也是一大块连续的内存. ...

随机推荐

  1. Redis集群研究和实践(基于redis 3.2.5)(一)

    前言 Redis 是我们目前大规模使用的缓存中间件,由于它强大高效而又便捷的功能,得到广泛的使 用. Redis在2015年发布了3.0.0,官方支持了redis cluster.至此结束了redis ...

  2. 绵阳2020CCPC补题

    绵阳2020CCPC D,K,J,L,G D. Defuse the Bombs 知识点:二分答案 复杂度:\(O(nlogn+log^2n)\) vp时我猜了一个结论,验了几个样例就写了,喜提WA3 ...

  3. npm安装hexo报错

    报错提示 npm WARN saveError ENOENT: no such file or directory, open '/home/linux1/package.json' npm noti ...

  4. 【Android】Configuration中的locale已过时

    Configuration中有很多属性的设置,在编译时提示错误说locale已过时这个是设置语言的 使用最新的方法如下 configuration.setLocale(locale);

  5. 第2-4-4章 规则引擎Drools规则属性-业务规则管理系统-组件化-中台

    目录 5. 规则属性 5.1 enabled属性 5.2 dialect属性 5.3 salience属性 5.4 no-loop属性 5.5 activation-group属性 5.6 agend ...

  6. Zookeeper的服务器的log4j升级为log4j2的升级方案(忽略配置化兼容问题)

    参考在线markdown编辑器: http://marxi.co/ Zookeeper的服务器的log4j升级为log4j2的升级方案(忽略配置化兼容问题) 目前希望可以升级将Zookeeper中lo ...

  7. jquery 简单分页插件jQuerypage

    昨天项目手机端要用到table的分页,考虑到手机端界面小,系统数据不多,在没考虑大批量数据处理的前提前就下载了这个插件,简单. 展示数据datas为json格式. <!DOCTYPE html& ...

  8. JavaScript入门⑤-欲罢不能的对象原型与继承-全网一般图文版

    JavaScript入门系列目录 JavaScript入门①-基础知识筑基 JavaScript入门②-函数(1)基础{浅出} JavaScript入门③-函数(2)原理{深入}执行上下文 JavaS ...

  9. python中文词云生成

    一.词云 "词云"就是对网络文本中出现频率较高的"关键词"予以视觉上的突出,形成"关键词云层"或"关键词渲染",从而过滤 ...

  10. Python matplotlib 学习——建立画布和坐标系

    #导入包import matplotlib.pyplot as plt #让图表在jupyter展示出来%matplotlib inline#解决中文乱码问题plt.rcParams["fo ...