在 Visual Studio 17.8 Preview 2 中,我们更新了单元测试分析,允许你在性能分析器中使用任何可用的工具——而不仅仅是仪表工具。有了这个更改,可以很容易地快速分析孤立的小工作单元,进行更改,然后重新度量和验证更改的影响。假设您有良好的测试覆盖率,这是利用现有资产来帮助优化应用程序性能的好方法。

谁动了我的奶酪?

  在这个新版本中,我们更新了单元测试分析体验。以前,当在单元测试上下文菜单中选择 profile 时,它在 Instrumentation 工具下运行,并且您在运行结束时得到报告。

  现在,当您选择一个 profile 时,Performance Profiler 启动页面将出现,您可以选择任何可用的工具。

  这让您可以使用 .NET Object Allocation 工具来分析单元测试,以查看所有的分配以及它们来自哪里。这是减少不必要的分配并验证更改的好方法。

让我们减少一些分配吧!

  现在我们可以使用任何工具了,让我们花5分钟看看我们是否可以从性能分析器中减少一些分配。首先,我有一个名为“VerifySimpleCallTree”的单元测试,我们使用它来验证我们的分析器是否正确地构建了一个调用树。在测试资源管理器中,我右键单击测试并选择“Profile”,得到 Performance Profiler,选择 .NET Object Allocation 工具,然后点击“Start”。从这里开始我的测试运行,一旦完成,我就会得到正常的分配报告,我可以用它来深入研究分配,看看我可以削减什么来减轻 GC 的负担。

  当我浏览这些类型时,我注意到分配了一堆 Enumerators 。虽然这不是直接错误,但它确实看起来很奇怪。通过回溯,我可以看到这是来自我们的 JmcConfigurationService,并且查看代码,可以肯定枚举器是从 Any() 扩展方法创建的。

this.patternsLock.EnterReadLock();
try
{
if (this.unknownModulePatterns.Any(t => t.IsMatch(moduleString)))
{
return JmcState.UnknownCode;
}
else if (this.systemModulePatterns.Any(t => t.IsMatch(moduleString)))
{
return JmcState.SystemCode;
}
else
{
return IsStringJmc(moduleString, this.excModulePatterns, this.incModulePatterns) ? JmcState.UserCode : JmcState.LibraryCode;
}
}
finally
{
this.patternsLock.ExitReadLock();
}

  通过使用静态局部函数快速重写,我们可以删除枚举数并减少分配。

this.patternsLock.EnterReadLock();
try
{
if (CheckMatch(this.unknownModulePatterns, moduleString))
{
return JmcState.UnknownCode;
}
else if (CheckMatch(this.systemModulePatterns, moduleString))
{
return JmcState.SystemCode;
}
else
{
return IsStringJmc(moduleString, this.excModulePatterns, this.incModulePatterns) ? JmcState.UserCode : JmcState.LibraryCode;
}
}
finally
{
this.patternsLock.ExitReadLock();
} static bool CheckMatch(List patterns, string moduleStr)
{
foreach (var pattern in patterns)
{
if (pattern.IsMatch(moduleStr))
{
return true;
}
} return false;
}

  在单元测试上重新运行分析器,我可以验证并结果:实际上,我已经删除了这些不必要的分配,并帮助减少了 GC 的负担。

  虽然这个小调整不会让我的应用神奇地快20%,但随着时间的推移慢慢减少不必要的分配是逐步提高应用性能的好方法。有了新的单元测试分析,就可以很容易地处理现有的测试资产,然后验证更改是否产生了预期的影响。

让我们知道你的想法!

  使用单元测试进行独立性能分析的能力令人敬畏。通过隔离特定的代码区域,很容易获得良好的前后跟踪,以比较和查看性能优化的影响。我们热切欢迎任何聪明的想法,看法,或有价值的见解,我们洗耳恭听!不要隐瞒,请随时与我们分享吧。

原文链接:https://devblogs.microsoft.com/visualstudio/a-unit-of-profiling-makes-the-allocations-go-away/

 

【译】A unit of profiling makes the allocations go away的更多相关文章

  1. 【译】Database Profiling with Visual Studio

    你是否在排查运行缓慢的 web 应用程序时怀疑是数据库层造成的?以前排查数据库层需要特定的工具,现在可以使用 Visual Studio 的 Performance Explorer 中的数据库分析工 ...

  2. 【译】Android API 规范

    [译]Android API 规范 译者按: 修改R代码遇到Lint tool的报错,搜到了这篇文档,aosp仓库地址:Android API Guidelines. 58e9b5f Project ...

  3. 「译」JUnit 5 系列:扩展模型(Extension Model)

    原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...

  4. 解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译)

    解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译) http://improve.dk/orcamdf-rawdatabase-a-swiss-a ...

  5. 解剖SQLSERVER 第十七篇 使用 OrcaMDF Corruptor 故意损坏数据库(译)

    解剖SQLSERVER 第十七篇 使用 OrcaMDF Corruptor 故意损坏数据库(译) http://improve.dk/corrupting-databases-purpose-usin ...

  6. [译]使用Continuous painting mode来分析页面的绘制状态

    Chrome Canary(Chrome “金丝雀版本”)目前已经支持Continuous painting mode,用于分析页面性能.这篇文章将会介绍怎么才能页面在绘制过程中找到问题和怎么利用这个 ...

  7. 配置SQL Server去使用 Windows的 Large-Page/Huge-Page allocations

    配置SQL Server去使用 Windows的 Large-Page/Huge-Page  allocations 目录表->页表->物理内存页 看这篇文章之前可以先看一下下面这篇文章 ...

  8. 怎么监视跟踪一个进程(Process)中的MS Unit Test DLL的详细性能(performance)【asp.net C#】

    Sample This tutorial will show how to instrument a unit test DLL for performance profiling. Visual S ...

  9. TCP传输小数据包效率问题(译自MSDN)

    TCP传输小数据包效率问题(译自MSDN) http://www.ftpff.com/blog/?q=node/16 摘要:当使用TCP传输小型数据包时,程序的设计是相当重要的.如果在设计方案中不对T ...

  10. QT unit test code coverage

    准备环境: qt-creator5.2.1 , gcov(gcc 默认安装),lcov(gcov 的图形化显示界面),qt_testlib 各环境介绍: 1.gcov   gcov 是一个可用于C/C ...

随机推荐

  1. Unity中的PostProcessScene:深入解析与实用案例

    Unity中的PostProcessScene:深入解析与实用案例 在Unity游戏开发中,我们经常需要对场景进行后处理,以实现更丰富的视觉效果.Unity提供了一个名为PostProcessScen ...

  2. 4.7 x64dbg 应用层的钩子扫描

    所谓的应用层钩子(Application-level hooks)是一种编程技术,它允许应用程序通过在特定事件发生时执行特定代码来自定义或扩展其行为.这些事件可以是用户交互,系统事件,或者其他应用程序 ...

  3. Typecho博客部署一言接口

    开始部署 下载代码上传至你的网站目录,把解压出来的文件夹改名为hitokoto 然后访问https://域名及文件路径/hitokoto查看效果 示例:https://sunpma.com/other ...

  4. ISP图像处理——紫边Purple Fringing检测

    之前写过文章记紫边的形成原因,以下小结改善方法 图像紫边存在数码相机.监控摄像头等数字成像图像,使用设备在逆光.大光圈条件下拍摄图像的高反差区域容易出现紫边,解决图像自编问题有助设备得到完美图像. 紫 ...

  5. Java作业_Day21_

    多线程 一.判断题(T为正确,F为错误),每题1分 1.如果线程死亡,它便不能运行.(T) 2.在Java中,高优先级的可运行线程会抢占低优先级线程.( T) 3.线程可以用yield方法使低优先级的 ...

  6. 大语言模型中一个调皮的EOS token

    背景 最近需要做一个微调的培训,所以不可避免地需要上手一下相关的微调,而受限于机器资源,暂时没法做全参数微调,所以就尝试了目前比较火的两种高效微调方式,分别是PTuning和LoRA.模型选择得自然是 ...

  7. SpringBoot3分库分表

    标签:ShardingSphere5.分库.分表: 一.简介 分库分表的设计和实现方式,在之前的内容中总结过很多,本文基于SpringBoot3和ShardingSphere5框架实现数据分库分表的能 ...

  8. AI绘画工具MJ新功能有点东西,小白也能轻松一键换装

    先看最终做出来的效果 直接来干货吧.Midjourney,下面简称MJ 1.局部重绘功能来袭 就在前两天,MJ悄咪咪上线了这个被众人期待的新功能:局部重绘. 对于那些追求创新和个性化的设计师来说,局部 ...

  9. 机器学习-评价指标-AUCROC

    The Area Under the Receiver Operating Characteristic (AUC-ROC) curve is a performance metric commonl ...

  10. Linux下MySQL备份指定数据库命令

    比如我们要备份mysql中已经存在的名为linux的数据库,要用到命令mysqldump 命令格式如下: [root@linuxsir01 root]# mysqldump -u root -p li ...