如何使用 BenchmarkDotNet 對 C# 代碼進(jìn)行基準(zhǔn)測試

BenchmarkDotNet 是一個(gè)輕量級,開源的,強(qiáng)大的 .NET 工具包,它可以將你的方法轉(zhuǎn)化為基準(zhǔn)并跟蹤這些方法,最后對這些方法的性能提供一些測試報(bào)告,使用 BenchmarkDotNet 玩 基準(zhǔn)測試 是非常容易的。
你可以利用 BenchmarkDotNet 在 .NET Framework 和 .NET Core 應(yīng)用程序上實(shí)現(xiàn)基準(zhǔn)測試,在這篇文章中,我們將會討論如何在 .NET Core 中實(shí)現(xiàn)基準(zhǔn)測試。
安裝 BenchmarkDotNet
要想使用 BenchmarkDotNet,要么通過 Nuget 可視化窗口安裝 BenchmarkDotNet,要么使用NuGet Package Manager Console 命令行窗口輸入如下命令。
Install-Package BenchmarkDotNet
什么是基準(zhǔn)測試
基準(zhǔn)測試 是對應(yīng)用程序的一段代碼的性能提供一個(gè)或者一組度量值,度量代碼本質(zhì)上來說就是讓你清楚的了解你的應(yīng)用程序的性能到底是怎么樣的,當(dāng)你想優(yōu)化代碼的時(shí)候,如果手邊有這些性能度量值那該有多好呀~ 基準(zhǔn)測試也可以幫助我們縮小到那些必須要重構(gòu)的代碼。
創(chuàng)建基準(zhǔn)測試代碼
新建 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)測試, 做法很簡單,在方法上標(biāo)記 Benchmark 特性即可,接下來就可以 Main 方法中啟動 基準(zhǔn)測試,代碼如下:
static void Main(string[] args)
{
var summary = BenchmarkRunner.Run<MemoryBenchmarkerDemo>();
}
運(yùn)行 benchmark
值得注意的是,一定要用 release 模式運(yùn)行,如果用debug的話,會拋如下錯(cuò)誤的。

調(diào)整為 release 模式后,將程序跑起來,要稍微跑一段時(shí)間,最后將會看到 console 輸出如下的 summary。

從圖中可以看到,summary中會包含比如:BenchmarkDotNet版本,操作系統(tǒng),計(jì)算機(jī)硬件,.NET版本,編譯器信息和一些應(yīng)用程序相關(guān)的性能信息,從圖中也可以看出 ConcatStringUsingStringBuilder 方法比 ConcatStringUsingGenericList 方法性能更高,付出的代價(jià)就是占用更多的內(nèi)存。
接下來在 MemoryBenchmarkerDemo 類上標(biāo)注 RankColumn 標(biāo)記,這樣會在輸出結(jié)構(gòu)中多一個(gè)給程序排名的 Rank 列,修改代碼如下:
[MemoryDiagnoser, RankColumn]
public class MemoryBenchmarkerDemo
{
...
}
接下來再將程序跑起來,觀察最后的 summary,可以清楚的看到多了一個(gè) Rank 列。

BenchmarkDotNet 提供了一種簡單的方式讓你擁有了對應(yīng)用程序的性能知情權(quán),如果你想了解更多關(guān)于如何在 ASP.NET Core 中使用 BenchmarkDotNet,參考github:https://github.com/aspnet/benchmarks
譯文鏈接:https://www.infoworld.com/article/3573782/how-to-benchmark-c-code-using-benchmarkdotnet.html
【推薦】.NET Core開發(fā)實(shí)戰(zhàn)視頻課程 ★★★
.NET Core實(shí)戰(zhàn)項(xiàng)目之CMS 第一章 入門篇-開篇及總體規(guī)劃
【.NET Core微服務(wù)實(shí)戰(zhàn)-統(tǒng)一身份認(rèn)證】開篇及目錄索引
Redis基本使用及百億數(shù)據(jù)量中的使用技巧分享(附視頻地址及觀看指南)
.NET Core中的一個(gè)接口多種實(shí)現(xiàn)的依賴注入與動態(tài)選擇看這篇就夠了
10個(gè)小技巧助您寫出高性能的ASP.NET Core代碼
用abp vNext快速開發(fā)Quartz.NET定時(shí)任務(wù)管理界面
在ASP.NET Core中創(chuàng)建基于Quartz.NET托管服務(wù)輕松實(shí)現(xiàn)作業(yè)調(diào)度
現(xiàn)身說法:實(shí)際業(yè)務(wù)出發(fā)分析百億數(shù)據(jù)量下的多表查詢優(yōu)化
