使用 BenchmarkDotNet 對(duì) C# 代碼進(jìn)行基準(zhǔn)測(cè)試
BenchmarkDotNet 是一個(gè)輕量級(jí),開源的,強(qiáng)大的 .NET 工具包,它可以將你的方法轉(zhuǎn)化為基準(zhǔn)并跟蹤這些方法,最后對(duì)這些方法的性能提供一些測(cè)試報(bào)告,使用 BenchmarkDotNet 玩 基準(zhǔn)測(cè)試 是非常容易的。
你可以利用 BenchmarkDotNet 在 .NET Framework 和 .NET Core 應(yīng)用程序上實(shí)現(xiàn)基準(zhǔn)測(cè)試,在這篇文章中,我們將會(huì)討論如何在 .NET Core 中實(shí)現(xiàn)基準(zhǔn)測(cè)試。
安裝 BenchmarkDotNet
要想使用 BenchmarkDotNet,要么通過 Nuget 可視化窗口安裝 BenchmarkDotNet,要么使用NuGet Package Manager Console 命令行窗口輸入如下命令。
Install-Package BenchmarkDotNet
什么是基準(zhǔn)測(cè)試
基準(zhǔn)測(cè)試 是對(duì)應(yīng)用程序的一段代碼的性能提供一個(gè)或者一組度量值,度量代碼本質(zhì)上來說就是讓你清楚的了解你的應(yīng)用程序的性能到底是怎么樣的,當(dāng)你想優(yōu)化代碼的時(shí)候,如果手邊有這些性能度量值那該有多好呀~ 基準(zhǔn)測(cè)試也可以幫助我們縮小到那些必須要重構(gòu)的代碼。
創(chuàng)建基準(zhǔn)測(cè)試代碼
新建 BenchmarkDotNet 類,類定義如下
[MemoryDiagnoser] public class MemoryBenchmarkerDemo { int NumberOfItems = 100000; [Benchmark] public string ConcatStringsUsingStringBuilder() { var sb = new StringBuilder(); for (int i = 0; i < NumberOfItems; i++) { sb.Append("Hello World!" + i); } return sb.ToString(); } [Benchmark] public string ConcatStringsUsingGenericList() { var list = new List<string>(NumberOfItems); for (int i = 0; i < NumberOfItems; i++) { list.Add("Hello World!" + i); } return list.ToString(); } }
上面的代碼展示了如何做 基準(zhǔn)測(cè)試, 做法很簡(jiǎn)單,在方法上標(biāo)記 Benchmark 特性即可,接下來就可以 Main 方法中啟動(dòng) 基準(zhǔn)測(cè)試,代碼如下:
static void Main(string[] args) { var summary = BenchmarkRunner.Run<MemoryBenchmarkerDemo>(); }
運(yùn)行 benchmark
值得注意的是,一定要用 release 模式運(yùn)行,如果用debug的話,會(huì)拋如下錯(cuò)誤的。
調(diào)整為 release 模式后,將程序跑起來,要稍微跑一段時(shí)間,最后將會(huì)看到 console 輸出如下的 summary。
從圖中可以看到,summary中會(huì)包含比如:BenchmarkDotNet版本,操作系統(tǒng),計(jì)算機(jī)硬件,.NET版本,編譯器信息和一些應(yīng)用程序相關(guān)的性能信息,從圖中也可以看出 ConcatStringUsingStringBuilder 方法比 ConcatStringUsingGenericList 方法性能更高,付出的代價(jià)就是占用更多的內(nèi)存。
接下來在 MemoryBenchmarkerDemo 類上標(biāo)注 RankColumn 標(biāo)記,這樣會(huì)在輸出結(jié)構(gòu)中多一個(gè)給程序排名的 Rank 列,修改代碼如下:
[MemoryDiagnoser, RankColumn] public class MemoryBenchmarkerDemo { ... }
接下來再將程序跑起來,觀察最后的 summary,可以清楚的看到多了一個(gè) Rank 列。
BenchmarkDotNet 提供了一種簡(jiǎn)單的方式讓你擁有了對(duì)應(yīng)用程序的性能知情權(quán),如果你想了解更多關(guān)于如何在 ASP.NET Core 中使用 BenchmarkDotNet,參考github:https://github.com/aspnet/benchmarks
以上就是使用 BenchmarkDotNet 對(duì) C# 代碼進(jìn)行基準(zhǔn)測(cè)試的詳細(xì)內(nèi)容,更多關(guān)于BenchmarkDotNet 對(duì) C# 代碼進(jìn)行基準(zhǔn)測(cè)試的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C#實(shí)現(xiàn)多種圖片格式轉(zhuǎn)換的示例詳解
這篇文章主要為大家詳細(xì)介紹了C#如何實(shí)現(xiàn)多種圖片格式轉(zhuǎn)換,例如轉(zhuǎn)換成圖標(biāo)圖像ICO,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01使用WPF實(shí)現(xiàn)加載動(dòng)畫效果
在應(yīng)用程序加載大量數(shù)據(jù)或執(zhí)行復(fù)雜操作時(shí),為用戶提供一個(gè)良好的加載體驗(yàn)變得至關(guān)重要,加載動(dòng)畫是其中一個(gè)有效的方式,下面我們就來看看如何使用WPF實(shí)現(xiàn)簡(jiǎn)單的加載動(dòng)畫效果吧2024-03-03C#使用SqlServer作為日志數(shù)據(jù)庫(kù)的設(shè)計(jì)與實(shí)現(xiàn)
這篇文章主要給大家介紹了關(guān)于C#使用SqlServer作為日志數(shù)據(jù)庫(kù)的設(shè)計(jì)與實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01C#使用MiniExcel實(shí)現(xiàn)導(dǎo)入導(dǎo)出數(shù)據(jù)到Excel/CSV文件
MiniExcel是一個(gè)簡(jiǎn)單、高效避免OOM的.NET處理Excel查、寫、填充數(shù)據(jù)的工具,這篇文章主要介紹了C#如何使用MiniExcel實(shí)現(xiàn)導(dǎo)入導(dǎo)出數(shù)據(jù)到Excel/CSV文件,需要的可以參考下2024-02-02C#?form-data上傳圖片流到遠(yuǎn)程服務(wù)器的詳細(xì)代碼
這篇文章主要介紹了C#?form-data上傳圖片流到遠(yuǎn)程服務(wù)器的詳細(xì)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08C#讀取與寫入txt文件內(nèi)容的實(shí)現(xiàn)方法
在 C# 中讀取和寫入文本文件內(nèi)容是一個(gè)常見的任務(wù),本文主要介紹了使用幾種不同方法讀取和寫入文本文件的示例,并通過代碼示例介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-08-08