使用 BenchmarkDotNet 对 .NET 代码进行性能基准测试
前言
在软件开发领域,性能基准测试是确保软件系统高效、稳定运行的重要环节。它可以帮助你评估应用程序的性能,了解其在不同条件下的响应时间、吞吐量、资源利用率等。通过基准测试,你可以确定系统在处理特定工作负载时的性能表现。
项目介绍
BenchmarkDotNet 是一个基于.NET 开源、功能全面、易于使用的性能基准测试框架,它为.NET 开发者提供了强大的性能评估和优化能力。通过自动化测试、多平台支持、高级统计分析和自定义配置等特性,BenchmarkDotNet 帮助开发者更好地理解和优化软件系统的性能表现。
项目特性
支持的语言:C#、F#、Visual Basic。
支持的操作系统:Windows、Linux、macOS。
支持的架构:x86、x64、ARM、ARM64、Wasm 和 LoongArch64。
支持的运行时:.NET 5+、.NET Framework 4.6.1+、.NET Core 3.1+、Mono、NativeAOT。
创建控制台应用
创建名为:BenchmarkDotNetExercise的.NET 9 控制台应用。
安装 NuGet 包
在 NuGet 包管理器中搜索:BenchmarkDotNet 包进行安装:
进行性能基准测试
接下来我们对.NET 中常见的三种加密哈希函数:MD5、SHA256、SHA1进行性能基准测试,来一起分析一下哪一种哈希算法性能更优、效率更快。
HashFunctionsBenchmark
运行基准测试
注意一定要设置为:Release模式运行,假如为Debug模式会提示下面异常:
分析生成的报告
说明:
Mean: 所有测量值的算术平均值。
Error: 99.9% 置信区间的一半。
StdDev: 所有测量值的标准差。
Gen0: 第 0 代 GC 每 1000 次操作收集一次。
Gen1: 第 1 代 GC 每 1000 次操作收集一次。
Gen2: 第 2 代 GC 每 1000 次操作收集一次。
Allocated: 每次操作分配的内存(仅托管内存,包含所有内容,1KB = 1024B)。
1 ms: 1 毫秒(0.001 秒)。
报告分析:
MD5Hash 的平均耗时稍长于 SHA1Hash,但误差和标准差较小,性能稳定性较好,垃圾回收次数与 SHA1Hash 相同。
SHA256Hash 的平均耗时最长,但误差和标准差最小,性能稳定性最好,垃圾回收次数略少于 MD5Hash 和 SHA1Hash。
SHA1Hash 的平均耗时最短,但误差和标准差较大,表示其性能虽然优越但不太稳定。
性能测试多种格式输出
MarkdownExporter:导出 Markdown 格式。
AsciiDocExporter:导出 AsciiDoc 格式。
HtmlExporter:导出 HTML 格式。
CsvExporter:导出 CSV(逗号分隔值)格式。
RPlotExporter:导出 R 绘图文件格式。
项目源码地址
更多项目实用功能和特性欢迎前往项目开源地址查看👀,别忘了给项目一个 Star 支持💖。
开源地址:https://github.com/dotnet/BenchmarkDotNet
文章示例:https://github.com/YSGStudyHards/DotNetExercises/tree/master/BenchmarkDotNetExercise
优秀项目和框架精选
该项目已收录到 C#/.NET/.NET Core 优秀项目和框架精选中,关注优秀项目和框架精选能让你及时了解 C#、.NET 和.NET Core 领域的最新动态和最佳实践,提高开发工作效率和质量。坑已挖,欢迎大家踊跃提交 PR 推荐或自荐(让优秀的项目和框架不被埋没🤞)。
GitHub 开源地址:https://github.com/YSGStudyHards/DotNetGuide/blob/main/docs/DotNet/DotNetProjectPicks.md
Gitee 开源地址:https://gitee.com/ysgdaydayup/DotNetGuide/blob/main/docs/DotNet/DotNetProjectPicks.md
版权声明: 本文为 InfoQ 作者【追逐时光者】的原创文章。
原文链接:【http://xie.infoq.cn/article/7c5731eb05e49a4f72d53efdc】。文章转载请联系作者。







评论