成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺析池化對象 RecyclableMemoryStream 在 .netcore 中的使用

開發(fā) 前端
這篇文章我們將會討論 Microsoft.IO.RecyclableMemoryStream 及如何在 .NET Core 應(yīng)用程序中提升性能。

[[385657]]

 本文轉(zhuǎn)載自微信公眾號「碼農(nóng)讀書」,作者碼農(nóng)讀書。轉(zhuǎn)載本文請聯(lián)系碼農(nóng)讀書公眾號。

Microsoft.IO.RecyclableMemoryStream 是一個(gè)被設(shè)計(jì)為專門用于提高 Stream 操作的高性能類庫,意思很明顯,專用于取代 MemoryStream 而生,RecyclableMemoryStream 可以最大限度的避免 Stream 操作在 GC 上的 LOH (大對象堆)的分配和內(nèi)存碎片,泄露等煩人的問題,這篇文章我們將會討論 Microsoft.IO.RecyclableMemoryStream 及如何在 .NET Core 應(yīng)用程序中提升性能。

RecyclableMemoryStream 的價(jià)值

RecyclableMemoryStream 大體上提供了如下四點(diǎn)價(jià)值。

  • 使用緩沖池避免 LOH 分配。
  • 大大的減少生成到2代堆的可能,相對減少了 GC 回收時(shí)造成的線程停滯時(shí)間。
  • 避免了內(nèi)存碎片和內(nèi)存泄漏。
  • 提供了用于跟蹤和分析性能的度量值。

RecyclableMemoryStream 的原理

RecyclableMemoryStream 在2代堆上存儲了一個(gè)用于流的大型緩沖區(qū),并能夠確保這個(gè)緩沖區(qū)在進(jìn)程的生命周期內(nèi)一直存在,這就確保了GC不會頻繁的出現(xiàn)全量回收,同時(shí) RecyclableMemoryStreamManager 類維護(hù)了兩類緩沖池。

  • 小型緩沖池 常用于讀寫操作,每一個(gè)小池子大小為 128k。
  • 大型緩沖池 常用于當(dāng)有連續(xù)緩沖的場景下使用,每一個(gè)大池子大小為 1MB。

值得注意的是,大型緩沖池的擴(kuò)容又分為 線性增長 和 指數(shù)型增長,可以看出內(nèi)存可被高效的反復(fù)使用并且對調(diào)用者還是無感知的,這就是為什么 RecyclableMemoryStream 比 MemoryStream 更好更高效的原因。

當(dāng)調(diào)用 GetBuffer() 方法時(shí),小緩沖區(qū)將會轉(zhuǎn)換為一個(gè)大的連續(xù)緩沖區(qū),如下代碼所示:

  1. var buffer = recyclableMemoryStreamManager.GetStream().GetBuffer(); 

安裝 RecyclableMemoryStream

你可以通過 Nuget 可視化界面安裝 Microsoft.IO.RecyclableMemoryStream 或者通過 NuGet package manager console window 執(zhí)行如下命令。

  1. Install-Package Microsoft.IO.RecyclableMemoryStream 

使用 RecyclableMemoryStream

安裝好之后,接下來我們通過 RecyclableMemoryStream 將數(shù)據(jù)寫入到 MemoryStream 中,值得注意的是,RecyclableMemoryStreamManager.GetStream() 方法返回的是 MemoryStream 實(shí)例。

  1. class Program 
  2.  { 
  3.      private static readonly RecyclableMemoryStreamManager recyclableMemoryStreamManager = new RecyclableMemoryStreamManager(); 
  4.  
  5.      static void Main(string[] args) 
  6.      { 
  7.          string data = "This is a sample text message."
  8.  
  9.          var buffer = Encoding.ASCII.GetBytes(data); 
  10.           
  11.          using (var memoryStream = recyclableMemoryStreamManager.GetStream()) 
  12.          { 
  13.              memoryStream.Write(buffer, 0, buffer.Length); 
  14.          } 
  15.           
  16.          Console.ReadKey(); 
  17.      } 
  18.  } 

上面的代碼還有一點(diǎn)要注意,我將 RecyclableMemoryStreamManager 靜態(tài)化了,意味著它只需要定義一次就ok了,還有一點(diǎn)你可以對 MemoryStream 進(jìn)行標(biāo)記,方便后續(xù)持續(xù)跟蹤,如下代碼所示:

  1. using (var memoryStream = recyclableMemoryStreamManager.GetStream("High_Performance_Stream_Demo.Program.Main")) 
  2.             { 
  3.                 memoryStream.Write(buffer, 0, buffer.Length); 
  4.             } 

對 MemoryStream Pool 精細(xì)化配置

如果你想對 MemoryStream Pool 做更精細(xì)化的配置,可以在 RecyclableMemoryStreamManager 實(shí)例上進(jìn)行配置,如下代碼所示:

  1. int blockSize = 1024; 
  2. int largeBufferMultiple = 1024 * 1024; 
  3. int maximumBufferSize = 16 * largeBufferMultiple; 
  4. int maximumFreeLargePoolBytes = maximumBufferSize * 4; 
  5. int maximumFreeSmallPoolBytes = 250 * blockSize; 
  6. var recyclableMemoryStreamManager = new RecyclableMemoryStreamManager(blockSize, largeBufferMultiple, maximumBufferSize); 
  7. recyclableMemoryStreamManager.AggressiveBufferReturn = true
  8. recyclableMemoryStreamManager.GenerateCallStacks = true
  9. recyclableMemoryStreamManager.MaximumFreeLargePoolBytes = maximumFreeLargePoolBytes; 
  10. recyclableMemoryStreamManager.MaximumFreeSmallPoolBytes = maximumFreeSmallPoolBytes; 

RecyclableMemoryStream 最佳實(shí)踐

內(nèi)存碎片會影響到程序的性能,而且LOH獨(dú)有的鏈?zhǔn)焦芾硪卜浅H菀桩a(chǎn)生內(nèi)存碎片,下面是使用 RecyclableMemoryStream 應(yīng)該遵循的一些經(jīng)驗(yàn)法則。

  • 根據(jù)你的業(yè)務(wù)場景設(shè)置合適的 blockSize, largeBufferMultiple, maxBufferSize, MaximumFreeLargePoolBytes, MaximumFreeSmallPoolBytes 值。
  • 當(dāng)使用完 Stream 對象時(shí)一定要速速關(guān)閉。
  • 永遠(yuǎn)不要調(diào)用 ToArray() 方法。
  • 盡可能避免調(diào)用 GetBuffer() 方法。

Microsoft.IO.RecyclableMemoryStream 是 MemoryStream 的池化對象,它技巧性的減少了 GC 的負(fù)載并減少了 LOH 的大對象分配,自然就提高了應(yīng)用程序的性能,不僅避免了內(nèi)存碎片和內(nèi)存泄漏還提供了用于跟蹤性能的指標(biāo)。

譯文鏈接:https://www.infoworld.com/article/3597060/how-to-use-recyclablememorystream-in-net-core.html

責(zé)任編輯:武曉燕 來源: 碼農(nóng)讀書
相關(guān)推薦

2009-07-01 09:17:36

對象比較Java

2009-06-16 15:20:48

ApplicationJSP程序

2017-05-24 09:43:42

2009-09-29 16:11:45

Hibernate實(shí)現(xiàn)

2011-08-29 17:27:47

HTML 5交互移動應(yīng)用

2009-09-11 11:33:58

C# WinForm控Attribute

2009-09-28 13:23:54

HTTP編程

2010-03-15 17:17:29

Java線程池

2023-10-10 10:02:32

2009-08-25 15:15:08

C#對象序列化應(yīng)用

2021-07-27 22:56:00

JavaScript編程開發(fā)

2021-07-15 08:58:16

Spring對象引用

2012-06-13 09:29:28

2011-06-19 08:59:59

錨文本

2011-03-11 09:20:35

jQueryjavascript

2009-07-29 15:55:48

ASP.NET Req

2011-09-27 09:50:46

軟件項(xiàng)目管理

2009-07-08 15:31:40

JDK 6.0web service

2012-07-11 14:31:16

SpringAop

2009-09-09 14:45:41

XML序列化和反序列化
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日韩一级电影免费观看 | 91资源在线 | 午夜影院在线观看 | 成人av一区| 国产亚洲一区在线 | 中文字幕视频在线 | 亚洲欧美中文日韩在线v日本 | 欧美视频在线观看 | 91精品国产综合久久久动漫日韩 | 黄色在线免费观看 | 一本色道久久综合亚洲精品高清 | 久久亚洲综合 | 国产精品99久久久久久久久久久久 | 奇米av| 久久久久久网站 | 伊人精品在线 | 一二区成人影院电影网 | 国产一区二区影院 | 国产农村一级国产农村 | 91直接看| 日韩精品免费播放 | 中文字幕人成乱码在线观看 | 91大神在线资源观看无广告 | 午夜av免费| 网色 | 精品国偷自产在线 | 国产精品久久久久久久久久久久午夜片 | 久青草影院 | 综合久久99 | 欧美精品一二三 | 五月婷婷激情网 | 久草视频在线播放 | 日韩精品视频在线观看一区二区三区 | 伊人久久成人 | 午夜小视频免费观看 | 伦理一区二区 | 欧美精品一区二区三区在线 | 男女视频在线免费观看 | 亚洲精品99 | 国产精品成人av | 蜜桃视频在线观看免费视频网站www |