- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了一个简单的控制台应用程序,并通过 Run Command -> PerfMonTest.exe 从 PerfView 执行它
我获取日志文件并查看应用程序的进程。它如预期的那样昂贵(99% CPU),但是当我想深入了解昂贵的方法时,它们不会显示在昂贵的方法列表中。
我可以做些什么来让它们可见吗?
这是我选择进程时的 View 。我希望列表中有 CallExpensive 和 CallCheap:
选择 Main Methods 并没有给我机会进一步钻研被调用的方法
这是应用程序:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace PerfMonTest
{
class Program
{
static void Main(string[] args)
{
for (int i = 0; i <= 2000; i++)
{
CallExpensive(1000);
CallCheap(1000);
CallCheap(400);
}
}
public static void CallExpensive(int expense)
{
for (int i = 0; i <= expense; i++)
{
DateTime checkTime = DateTime.Now;
string val = "10" + i.ToString();
}
}
public static void CallCheap(int expense)
{
for (int i = 0; i <= expense; i++)
{
int j = 2;
}
}
}
}
最佳答案
从屏幕截图看来,您没有加载符号。如果这样做,您会发现大部分时间都花在 DateTime.Now
上。
如果您在 By Name View 中单击 Main
,您将转到 Callers View ,它会告诉您哪些方法称为 Main
。如果您想深入了解 Main
正在调用哪些方法,您需要转到 Callees View 。如果这样做,您将看到 Main
调用的分解。
但是,在这种特殊情况下,CallExpensive
和 CallCheap
的逻辑非常简单,方法将被内联(在 Release模式下)。因为这些方法是内联的,所以它们不会作为 Main
调用的一部分出现,因为代码已折叠到 Main
本身。
您可以在方法运行后通过附加调试器来验证方法是否已内联,并查看类型的方法描述符。这是我得到的输出:
0:004> !dumpmt -md 004737c0EEClass: 00471278Module: 00472e94Name: ConsoleApplication1.ProgrammdToken: 02000002File: C:\temp\ConsoleApplication1\ConsoleApplication1\bin\Release\ConsoleApplication1.exeBaseSize: 0xcComponentSize: 0x0Slots in VTable: 8Number of IFaces in IFaceMap: 0--------------------------------------MethodDesc Table Entry MethodDe JIT Name72064a00 71d66728 PreJIT System.Object.ToString()72058830 71d66730 PreJIT System.Object.Equals(System.Object)72058400 71d66750 PreJIT System.Object.GetHashCode()72051790 71d66764 PreJIT System.Object.Finalize()0047c01d 004737b8 NONE ConsoleApplication1.Program..ctor()004d0050 00473794 JIT ConsoleApplication1.Program.Main(System.String[])0047c015 004737a0 NONE ConsoleApplication1.Program.CallExpensive(Int32)0047c019 004737ac NONE ConsoleApplication1.Program.CallCheap(Int32)
CallExpensive
和 CallCheap
在 JIT 列中列出了 NONE
的事实表明它们是内联的(或者根本没有被调用,但是这里不是这种情况)。
关于performance - 我如何在 PerfView 中看到昂贵的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12828491/
如何获取特定 UTF-8 字符串的字节序列?我看到正则表达式引擎中的某些错误仅在某些边缘情况下才会触发,我想确切地知道它正在处理哪些数据。 最佳答案 也许 charToRaw ? > charToRa
考虑一个具有许多变量的 java 程序,其中一些是循环计数器,我希望看到这些变量随时间变化的值,而不是在代码中到处放置 print 语句。 为什么?我认为它可以帮助我轻松调试。 Example- in
有没有办法查看 JavaScript 正在创建的“线程”?例如,如果我有一个附加到 DOM 元素的事件处理程序,我假设 JavaScript 会隐式地创建一个新线程来在后台运行该代码?如果是这样,有没
我正在使用反射 API 来调用类运行时并调用其方法。但我看到 java.lang.reflect.InitationTargetException 异常。 我需要调用一个名为 - TestClass
考虑一个名为 t.cmd 的命令脚本,它只包含以下两行: @exit /b 123 @echo If you see this, THEN EXIT FAILED.. 因此,该脚本只是将脚本执行过程的
我最近一直在努力学习编程语言实用学第 3 版,以了解更多关于语言在底层如何工作的信息,并且通过查看由真正基本的 GCC 编译的 C 代码生成的程序集,我获得了很多进展.我开始对 C 系列的静态语言越来
最简单的制作方法是什么QWebView识别并正确加载网页上的 Flash? 最佳答案 似乎只需两行即可实现(当然,假设目标系统上安装了闪存): QWebSettings *settings = QWe
我想通过编程(使用VBA)访问其他人与我共享的日历。它们在我的Outlook中的“人民日历”下列出。我在网上搜索了此内容,所有建议所做的仅使我感到困惑。如何从“人的日历”中获取共享给我的所有日历的
使用MongoDB Compass,可以看到数据库用户或创建新用户吗? 最佳答案 香港专业教育学院在命令行上使用以下命令进行管理: mongo use (my database name) db.cr
我正在CentOS 7.4.1708(核心),Java(TM)SE运行时环境(内部版本1.8.0_152-b16)上运行eXist-db 3.6.1。我希望能够在person.xml中的最后一个记录之
我需要确认。 客户端 1 在事务内的表中插入行。 客户端 2 使用 SELECT 请求该表。如果在此客户端上隔离级别设置为 READ COMMITTED,您能否确认 SELECT 不会返回客户端 1
我刚刚安装了 python-dev: $ sudo apt-get install python-dev 这样我就可以开始使用 P4Python 了。但是当我尝试导入 P4 时,我得到: Traceb
我正在使用 msys 和 mingw 编译 libtorrent-rasterbar-0.16.16。./configure 运行良好,直到它进入 boost 库检查。我有 boost 1.51,我设
我在 GO 项目的 Travis CI 上有一个奇怪的行为。 [这里] 失败了,提示一个函数只接受 1 个参数并用 2 个参数调用。 src/finances-service/main.go:45:1
这个问题已经有答案了: What are enums and why are they useful? (27 个回答) 已关闭 4 年前。 作为 Java 初学者,我接触到了枚举,这让我对类型声明感
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
我正在使用 preactjs 创建我的应用程序。最重要的是,我正在使用剑道网格。在网格内,我想显示一个超链接。如果用户点击链接,它应该改变路线。为了呈现链接,我使用了 preact-router。 这
有没有办法只查看 Node.js 中的函数签名?我知道 fn.toString() 但不需要所有代码,只需要签名。 最佳答案 var source = fn.toString(); var signa
如何设置 vim 以查看我在 ubuntu 上安装的 ruby rvm。 rvm 已安装,ruby 从终端返回。 renshaw@renshaw-TravelMate-5740G:~$ ruby
我试图在我的 Android 应用程序中防止 OutOfMemoryError。我已经阅读了很多帖子,但我仍然无法解决。 该应用程序有后台 Activity ,所以我认为这是主要问题。 OutOfMe
我是一名优秀的程序员,十分优秀!