日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

BenchmarkDotNet的使用

發布時間:2025/5/22 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BenchmarkDotNet的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我的高級架構師告訴我,檢驗程序性能時不要用DateTime.Now相減或者StopWatch,最好用BenchmarkDotNet,于是我就試了一下。
上手體驗后感覺BenchmarkDotNet大致的特點如下:

  • 用起來還比較簡單,在對應的method上面打上[Benchmark]標記即可;
  • 通過var summary = BenchmarkRunner.Run();來啟動;
  • 要求class和method必須是public;
  • 要求程序必須是Release;
  • 會自動將程序中打標記的對應模塊跑很多遍,最后給出均值和偏差;
  • 使用前要在NuGet管理器中,或者在包管理器的PM終端中安裝BenchmarkDotNet。

    最后上代碼(以測試SeriLog和原生StreamWriter的效率對比為例):

    // See https://aka.ms/new-console-template for more information using BenchmarkDotNet.Attributes; using BenchmarkDotNet.Running; using Serilog; using Serilog.Core;SerilogTest.Program.main();namespace SerilogTest {public class Program{Logger _log2Console = new LoggerConfiguration().WriteTo.Console().CreateLogger();Logger _log2File = new LoggerConfiguration().WriteTo.File("seri.log").CreateLogger();private StreamWriter _sw2File = new StreamWriter("sq.log");private int _loopMaxTime = 100;[Benchmark]public double Seri2ConsoleI(){DateTime tmpStartTime = System.DateTime.Now;for (int i = 1; i < _loopMaxTime; i++){_log2Console.Information($"Serilog info {i}");}Log.CloseAndFlush();DateTime tmpEndTime = System.DateTime.Now;TimeSpan tmpTimeCost = tmpEndTime.Subtract(tmpStartTime);return Math.Round(tmpTimeCost.TotalMilliseconds, 2, MidpointRounding.AwayFromZero);}[Benchmark]public double Seri2ConsoleE(){DateTime tmpStartTime = System.DateTime.Now;for (int i = 1; i < _loopMaxTime; i++){_log2Console.Error($"Serilog error {i}");}Log.CloseAndFlush();DateTime tmpEndTime = System.DateTime.Now;TimeSpan tmpTimeCost = tmpEndTime.Subtract(tmpStartTime);return Math.Round(tmpTimeCost.TotalMilliseconds, 2, MidpointRounding.AwayFromZero);}[Benchmark]public double Seri2FileI(){DateTime tmpStartTime = System.DateTime.Now;for (int i = 1; i < _loopMaxTime; i++){_log2File.Information($"Serilog info {i}");}Log.CloseAndFlush();DateTime tmpEndTime = System.DateTime.Now;TimeSpan tmpTimeCost = tmpEndTime.Subtract(tmpStartTime);return Math.Round(tmpTimeCost.TotalMilliseconds, 2, MidpointRounding.AwayFromZero);}[Benchmark]public double Seri2FileE(){DateTime tmpStartTime = System.DateTime.Now;for (int i = 1; i < _loopMaxTime; i++){_log2File.Error($"Serilog error {i}");}Log.CloseAndFlush();DateTime tmpEndTime = System.DateTime.Now;TimeSpan tmpTimeCost = tmpEndTime.Subtract(tmpStartTime);return Math.Round(tmpTimeCost.TotalMilliseconds, 2, MidpointRounding.AwayFromZero);}[Benchmark]public double Stream2File(){DateTime tmpStartTime = System.DateTime.Now;for (int i = 1; i < _loopMaxTime; i++){_sw2File.WriteLine($"{tmpStartTime.ToString()}.077 +08:00 [ERR] Stream Writer {i}");}_sw2File.Flush();DateTime tmpEndTime = System.DateTime.Now;TimeSpan tmpTimeCost = tmpEndTime.Subtract(tmpStartTime);return Math.Round(tmpTimeCost.TotalMilliseconds, 2, MidpointRounding.AwayFromZero);}[Benchmark]public double Stream2Console(){DateTime tmpStartTime = System.DateTime.Now;for (int i = 1; i < _loopMaxTime; i++){Console.WriteLine($"{tmpStartTime.ToString()}.077 +08:00 [ERR] Console Write {i}");}DateTime tmpEndTime = System.DateTime.Now;TimeSpan tmpTimeCost = tmpEndTime.Subtract(tmpStartTime);return Math.Round(tmpTimeCost.TotalMilliseconds, 2, MidpointRounding.AwayFromZero);}public static void main(){var summary = BenchmarkRunner.Run<Program>();/*double SeriConcolsErrorCost = Seri2ConsoleE();double SeriConcolsInfoCost = Seri2ConsoleI();double SeriFileErrorCost = Seri2FileE();double SeriFileInfoCost = Seri2FileI();double SystConsoleInfoCost = Stream2Console();double SystFileInfoCost = Stream2File();Console.WriteLine($"[To Console]:\n" +$" Seri info: { SeriConcolsInfoCost }ms\n" +$" Seri err: { SeriConcolsErrorCost }ms\n" +$" Sys output: { SystConsoleInfoCost }ms\n" +$"[To file]:\n" +$" Seri info: { SeriFileInfoCost }ms\n" +$" Seri error: { SeriFileErrorCost }ms\n" +$" Sys output: { SystFileInfoCost }ms\n");*/}} }

    運行結果如下:

    結果日志也會保存在新生成的BenchmarkDotNet.Artifacts目錄中。

    總結

    以上是生活随笔為你收集整理的BenchmarkDotNet的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 中文字幕日韩一区二区三区不卡 | 国产aⅴ片 | 又黄又刺激的视频 | 国产九九九 | 黄色片aa | 激情小说中文字幕 | 国产精品美女一区二区 | 亚洲A∨无码国产精品 | 精品人妻一区二区三区久久 | 欧美精品久久天天躁 | 亚洲色图第1页 | 亚洲精品一区二区三区精华液 | 免费日韩av| 日日插插| 国产第八页 | 成人人人人人欧美片做爰 | 久久成人a毛片免费观看网站 | 性做久久久久久久 | 中文写幕一区二区三区免费观成熟 | 99国产精品久久久久久久成人 | 一级特黄aaa大片 | 国产原创av在线 | 欧美视频在线观看一区二区三区 | 小日子的在线观看免费第8集 | 亚洲三级电影网站 | 日韩一二三级 | 精品国产一区二区三区久久久蜜月 | 国产+日韩+欧美 | 亚洲欧洲国产视频 | 欧美日韩一区二区在线观看视频 | 少妇一级淫免费播放 | 五月激情在线 | 欧美第一页浮力影院 | 亚洲综合色婷婷 | 亚洲一区在线观看视频 | www.奇米.com| 古装三级吃奶做爰 | 69久久精品无码一区二区 | 超碰伊人| 美女视频在线观看免费 | 国产不卡在线 | 青青青国内视频在线观看软件 | 美女日日日 | 精品97人妻无码中文永久在线 | 欧美精品乱码久久久久久按摩 | 国产精选久久久 | h片在线免费观看 | 91免费看网站 | 第一福利视频 | 日韩一区二区三区中文字幕 | 性欧美最猛 | 人妻熟女一区二区三区app下载 | 天降女子在线观看 | 欧美无马 | 婷婷久久网| 免费黄色在线观看 | 中文字幕人乱码中文字 | a视频免费 | 草视频在线 | 91精品国产91久久久久福利 | 色婷婷91 | 欧美二区视频 | 成人黄色免费在线观看 | 亚洲天堂2016 | 在线播放无码后入内射少妇 | 亚洲国产日韩一区 | 无码人妻久久一区二区三区 | 黄色a毛片| 狠狠操天天操夜夜操 | 亚洲永久精品国产 | 玖玖zyz| 中文字幕无线精品亚洲乱码一区 | 精品视频一区二区三区四区 | 日韩三级av在线 | 欧美色图另类 | 天堂在线国产 | 最新黄色网址在线观看 | 国产wwwwww | 国产传媒国产传媒 | 久久久久性色av无码一区二区 | 国产偷自拍视频 | 天天干视频在线观看 | 老鸭窝视频在线观看 | 激情国产视频 | 亚洲精品一区二区在线 | 九九热视频免费观看 | 新版红楼梦在线高清免费观看 | 草草影院av| www.九九热| 苏晴忘穿内裤坐公交车被揉到视频 | 法国经典free性复古xxxx | 日本高清视频一区二区三区 | 青青草色视频 | 日韩少妇一区二区三区 | 西西大胆午夜视频 | 欧美18一20男同69gay | 亚洲精品视频在线观看免费视频 | 国产 欧美 日韩 在线 | 男女爽爽爽 |