使用 Benchmark.NET 测试代码性能
今天,我們將研究如何使用Benchmark.Net來測(cè)試代碼性能。借助基準(zhǔn)測(cè)試,我們可以創(chuàng)建基準(zhǔn)來驗(yàn)證所做的更改是否按預(yù)期工作并且不會(huì)導(dǎo)致性能下降。
并非每個(gè)項(xiàng)目都需要進(jìn)行基準(zhǔn)測(cè)試,但是如果您正在開發(fā)的是NuGet程序包或通用dll,則很有意義。我們將使用它來解決一個(gè)古老的問題,字符串拼接,比如下面這樣:
string myString = "string1" + "string2" + "string3" + "string4" + "string5"; Console.WriteLine(myString);我們很多人都知道建議使用StringBuilder作為替代方法,并且速度要快得多,特別是在您有很多字符串的情況下。
StringBuilder sb = new StringBuilder(); sb.Append("string1"); sb.Append("string2"); sb.Append("string3"); sb.Append("string4"); sb.Append("string5"); Console.WriteLine(sb.ToString());Benchmark.NET
首先,我們需要?jiǎng)?chuàng)建一個(gè)控制臺(tái)項(xiàng)目,BenchmarkTesting.App
接下來,我們添加NuGet包?BenchmarkDotNet
然后,修改 program.cs文件中,把可訪問性改成 public
現(xiàn)在我們可以創(chuàng)建一些測(cè)試方法,我們直接修改program.cs, 每個(gè)測(cè)試方法都需要?[Benchmark]?特性,我創(chuàng)建了三個(gè)示例,分別使用+運(yùn)算符,Linq的Concat函數(shù)和使用StringBuilder拼接。
最后,在控制臺(tái)應(yīng)用程序的Main入口點(diǎn)中,添加 BenchmarkRunning Run命令:
然后我們使用下邊的命令運(yùn)行測(cè)試,或者直接使用VS啟動(dòng)項(xiàng)目,需要切換到Release模式下
dotnet run -p BenchmarkTesting.app.csproj -c Release運(yùn)行大約需要幾分鐘,基準(zhǔn)測(cè)試工具在后臺(tái)創(chuàng)建大量線程/作業(yè)并多次運(yùn)行測(cè)試,為了獲得一致的結(jié)果,建議最小化打開的應(yīng)用程序,并且在運(yùn)行時(shí)不要執(zhí)行任何其他操作,輸出如下所示,其中包含很多信息。
單位"us"是"μs"或微秒的縮寫,一微秒等于一毫秒的1/1000。
由此可見,StringBuilder要比+運(yùn)算符效率更高,Linq Concat函數(shù)也相對(duì)高效,但還是沒有StringBuilder快。
總結(jié)
拼接字符串時(shí)使用StringBuilder!本篇文章只是簡(jiǎn)單作的做了介紹,Benchmark.NET是測(cè)試性能的非常強(qiáng)大的工具,如果需要構(gòu)建Nuget包,或者開發(fā)通用類庫(kù)時(shí),這將是一種很好的測(cè)試方法。
原文鏈接:?https://samlearnsazure.blog/2021/01/12/measuring-code-performance-with-benchmark-net/[1]
歡迎關(guān)注我們的公眾號(hào) 【全球技術(shù)精選】,專注國(guó)外優(yōu)秀博客的翻譯和開源項(xiàng)目分享,也可以添加QQ群 897216102
??
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的使用 Benchmark.NET 测试代码性能的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C# 接口(Interface)
- 下一篇: 腾讯招.NET要求以下几点,你准备好了吗