在运行时,实际上没有任何"MSIL"堆栈.即使在调试模式下,执行的代码也始终是JIT编译的.JIT编译MSIL的过程将其从虚拟堆栈机"扁平化"为您运行的平台的普通汇编代码.这意味着如果值已经存在于寄存器中,那么ldloc.0可能最终会被转换为类似mov eax, [sp + 4]甚至是无操作的东西.如果要调试特定指令ldloc,则必须在dissasembly中查看它以查看ldoloc被转换为什么以及它实际从何处加载数据.
WinDbg + SoS工具(在另一篇文章中提到)将帮助您从托管代码的角度查看CPU堆栈.但是,他们不允许您看到"MSIL"堆栈,因为没有人可以看到.
| 归档时间: |
|
| 查看次数: |
249 次 |
| 最近记录: |