首页 > 其他分享 >BenchmarkDotNet

BenchmarkDotNet

时间:2024-04-21 13:00:24浏览次数:26  
标签:测试运行 AttributeTargets Benchmark 中位数 BenchmarkDotNet 测试

目录


官方开源地址和文档

GitHub:GitHub - dotnet/BenchmarkDotNet: Powerful .NET library for benchmarking

文档首页:Overview | BenchmarkDotNet

How it works

hand-right https://benchmarkdotnet.org/articles/guides/how-it-works.html

BenchmarkDotNet follows the following steps to run your benchmarks:

  1. BenchmarkRunner generates an isolated project per each runtime settings and builds it in Release mode.

  2. Next, we take each method/job/params combination and try to measure its performance by launching benchmark process several times (LaunchCount).

  3. An invocation of the workload method is an operation . A bunch of operation is an iteration . If you have an IterationSetup method, it will be invoked before each iteration, but not between operations. We have the following type of iterations:

    • Pilot: The best operation count will be chosen.
    • OverheadWarmup, OverheadWorkload: BenchmarkDotNet overhead will be evaluated.
    • ActualWarmup: Warmup of the workload method.
    • ActualWorkload: Actual measurements.
    • Result = ActualWorkload - <MedianOverhead>
  4. After all of the measurements, BenchmarkDotNet creates:

    • An instance of the Summary class that contains all information about benchmark runs.
    • A set of files that contains summary in human-readable and machine-readable formats.
    • A set of plots.

Choosing RunStrategy

If you run a benchmark, you always (explicitly or implicitly) use a job. Each Job has the RunStrategy parameter which allows switching between different benchmark modes. The default RunStrategy is Throughput, and it works fine for most cases. However, other strategies are also useful in some specific cases.

hand-right https://benchmarkdotnet.org/articles/guides/choosing-run-strategy.html

简单使用示例

Program.cs

    /// <summary>
    /// https://benchmarkdotnet.org/articles/overview.html
    /// </summary>
    internal class Program
    {
        static void Main(string[] args)
        {
            //var hashHelper = new Md5VsSha256();
            //var byte1 = hashHelper.Md5();
            //var byte2 = hashHelper.Sha256();
            //var isEqual = byte1.SequenceEqual(byte2);


            var summary = BenchmarkRunner.Run<Md5VsSha256>();
            Console.ReadLine();
        }
    }

Md5VsSha256.cs

    [MemoryDiagnoser]
    //[SimpleJob(RunStrategy.ColdStart)]
    [SimpleJob(RunStrategy.ColdStart, iterationCount: 5)]
    public class Md5VsSha256
    {
        private const int N = 10000;
        private readonly byte[] data;

        private readonly SHA256 sha256 = SHA256.Create();
        private readonly MD5 md5 = MD5.Create();

        public Md5VsSha256()
        {
            data = new byte[N];
            new Random(42).NextBytes(data);
        }

        [Benchmark]
        public byte[] Sha256() => sha256.ComputeHash(data);

        [Benchmark(Baseline = true)]
        public byte[] Md5() => md5.ComputeHash(data);
    }

BenchmarkDotNet打印列的含义

列名 含义
Method 测试方法的名称
Mean 测试运行的平均时间
Error 测试运行的标准误差,标准误差是测试结果的离散程度的度量,标准误差越小,表示测试结果越稳定
StdDev 所有测试运行的标准偏差,标准偏差是测试结果的离散程度的度量,标准偏差越小,表示测试结果越接近平均值。
Median 所有测试运行的中位数。中位数是测试结果的中间值,如果测试结果的个数为奇数,则中位数为中间的那个值;如果测试结果的个数为偶数,则中位数为中间两个值的平均值。
Ratio 每个测试运行的平均时间与基准测试运行的平均时间的比值。基准测试是性能最好的测试,它的比值为 1.0。其他测试的比值表示它们相对于基准测试的性能表现,比值越小,表示性能越好。
RatioSD 所有测试运行的比值的标准偏差。标准偏差越小,表示比值的离散程度越小,测试结果更稳定。
Gen 0 所有测试运行期间生成的第 0 代垃圾回收的次数。垃圾回收是 .NET 运行时自动回收不再使用的内存的机制,Generational Garbage Collection 是 .NET 中的一种垃圾回收算法。
Gen 1 所有测试运行期间生成的第 1 代垃圾回收的次数。
Gen 2 所有测试运行期间生成的第 2 代垃圾回收的次数。
Allocated 所有测试运行期间分配的内存总量。

Benchmark输出列

含义
[MemoryDiagnoser] 输出内存分配及回收信息,会输出:
Gen0
Gen1
Gen2
Allocated
Alloc Ratio 列信息
[RankColum] 输出排名信息,会输出:
Rank 列信息
MinColumn
MaxColumn
MeanColumn
MedianColumn 所有测试运行的中位数。中位数是测试结果的中间值,如果测试结果的个数为奇数,则中位数为中间的那个值;如果测试结果的个数为偶数,则中位数为中间两个值的平均值。

Benchmark特性

特性 作用于 含义
Benchmark AttributeTargets.Method
[Benchmark(Baseline = true)] AttributeTargets.Method 定义基线方法,详见:IntroBenchmarkBaseline
[Params(true, false)] AttributeTargets.Property
AttributeTargets.Field
IntroParams
[Arguments(100, 10)] AttributeTargets.Method IntroArguments
[SimpleJob(RunStrategy.ColdStart)] AttributeTargets.Class 冷启动模式,没有试点和预热阶段,详见:IntroColdStart
[DryJob] AttributeTargets.Class 只运行基准一次,会输出反汇编结果,详见:IntroDisassemblyDry
[GlobalSetup]
[GlobalCleanup]
AttributeTargets.Method IntroSetupCleanupGlobal

相关参考

  1. 性能基准测试工具 --- BenchmarkDotNet

版权特别声明

本文只用于记录本人使用BenchmarkDotNet时的一些参考,不做任何其他用途,其中参考的文章在 相关参考 中也给出了原文地址。

标签:测试运行,AttributeTargets,Benchmark,中位数,BenchmarkDotNet,测试
From: https://www.cnblogs.com/lanwah/p/18148807

相关文章

  • BenchmarkDotNet-Intro
    有些时候我们实现了某个功能,但是仅仅通过有限的几次调用无法知道这个功能的执行效率以及资源占用情况,此时就可以使用Benchmark对这个功能进行基准测试在dotnet中主要使用BenchmarkDotNetBenchmarkDotNet是一个.NET的基准测试框架,主要用于测量.NET程序的性能它可以......
  • NetBenchmarkDotNet性能测试
    案例usingBenchmarkDotNet.Attributes;usingBenchmarkDotNetDemo.Model;usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Runtime.InteropServices;usingSystem.Text;usingSystem.Threading.Tasks;namespaceBenchmarkDotNetDemo......
  • 基准测试工具 --- BenchmarkDotNet
    介绍今天介绍一个非常强大的基于.Net的基准测试工具BenchmarkDotNet。BenchmarkDotNet已经被14300多个项目采用,包括非常多的知名开源项目,例如dotnet/performance(.Net所有运行时的基准测试项目)dotnet/runtime(.Net运行时库),Roslyn(c#和VisualBasic编译器),Mono、ASP.NET......
  • 基准测试工具 --- BenchmarkDotNet
    介绍今天介绍一个非常强大的基于.Net的基准测试工具BenchmarkDotNet。BenchmarkDotNet已经被14300多个项目采用,包括非常多的知名开源项目,例如dotnet/performance(.Net所有运行时的基准测试项目)dotnet/runtime(.Net运行时库),Roslyn(c#和VisualBasic编译器),Mono、ASP.NET......
  • 基准测试BenchmarkDotNet
    今天飞书群里同事争论枚举.GetHashCode()会装箱,要改为(int)枚举,争吵不下纸上谈兵无法说服另外的人,上BenchmarkDotNet基准测试添加BenchmarkDotNet库<PackageReferenceInclude="BenchmarkDotNet"Version="0.13.5"/>性能测试用例classProgram{ staticvoidMain(strin......
  • BenchmarkDotNet 概述--性能测试
    BenchmarkDotNet概述BenchmarkDotNethelpsyoutotransformmethodsintobenchmarks,tracktheirperformance,andsharereproduciblemeasurementexperiments.It'snoharderthanwritingunittests提取几个关键字(其实是只认识那几个英文单词)将方法转换基准测......
  • BenchmarkDotNet 基准测试 .NET 库
    BenchmarkDotNet:功能强大的用于基准测试.NET库    出处:https://www.cnblogs.com/xueweihan/p/11745280.html......
  • 使用 BenchmarkDotNet 比较指定容量的 List 的性能
    我们之前提到List是.NET中常用的数据结构,其在存储大量数据时,如果能够指定它的初始化容量,就会有性能提升。这个优化的方法并不是很明显,因此本文将使用BenchmarkDotNet......