C#-BenchmarkDotNet的仅显示摘要部分

我正在对一些.net框架进行基准测试,正在使用.net框架,C#和BenchmarkDotNet

我想做的是我正在编写许多基准测试,并且只对报告的摘要部分感兴趣.如何配置BenchmarkDotNet仅显示测试的摘要部分?

这是一个更清晰的屏幕截图;

C#-BenchmarkDotNet的仅显示摘要部分

解决方法:

为什么要跳过日志?基准测试可能会花费很多时间,如果禁用日志,您将在黑屏上看到一段时间.如果出现问题,那么您将一无所知.

但是,有一种解决方法. BenchmarkDotNet使用特殊的Configs进行自定义.记录器是这些配置的一部分.如果您未指定任何配置,则将使用默认配置.您可以轻松地对其进行扩展,但是没有很好的API可以禁用默认配置的一部分(希望很快会被添加;相应的API现在处于讨论阶段).因此,您必须定义自己的配置,添加默认配置(记录器除外)的所有部分,并将其传递给BenchmarkRunner.然后,将不使用ConsoleLogger.之后,您必须打印摘要表和结论以手动进行控制台.同样,完整日志和Markdown格式的摘要表将位于BenchmarkDotNet.Artifacts文件夹中.

源代码:

var config = new ManualConfig();
config.Add(DefaultConfig.Instance.GetColumnProviders().ToArray());
config.Add(DefaultConfig.Instance.GetExporters().ToArray());
config.Add(DefaultConfig.Instance.GetDiagnosers().ToArray());
config.Add(DefaultConfig.Instance.GetAnalysers().ToArray());
config.Add(DefaultConfig.Instance.GetJobs().ToArray());
config.Add(DefaultConfig.Instance.GetValidators().ToArray());
config.UnionRule = ConfigUnionRule.AlwaysUseGlobal; // Overriding the default

var summary = BenchmarkRunner.Run<TestBench>(config);

var logger = ConsoleLogger.Default;
MarkdownExporter.Console.ExportToLog(summary, logger);
ConclusionHelper.Print(logger, config.GetCompositeAnalyser().Analyse(summary).ToList());
上一篇:小程序开发----自定义会员卡卡号和用户领取,以及简单介绍卡券功能和注意事项


下一篇:微信小程序入门笔记-使用云开发(4)