C# 堆栈跟踪不包括对新运算符的调用

本文关键字:运算符 调用 堆栈 跟踪 不包括 | 更新日期: 2023-09-27 17:55:42

我来自C++,我不明白为什么在 C# 中写:

class A {
    public A(){ /*here I get the StackTrace */}
    //......other code
    void f(){ A a = new A();
}

当我检查构造函数中的 StackTrace 对象时,我找不到在"f()"函数调用和"A()"构造函数之间对 new() 运算符的调用。

为什么省略了 new() 运算符? 还是我做错了什么?

C# 堆栈跟踪不包括对新运算符的调用

没有单独的new函数调用。只是构造函数调用。

我的 .Net 反汇编技能可能很弱,但这是我分配两个不同对象的结果:

        {
00000022  nop 
            new Object();
00000023  mov         ecx,79B9F5E8h 
00000028  call        FD95FB90 
0000002d  mov         dword ptr [ebp-3Ch],eax 
00000030  mov         ecx,dword ptr [ebp-3Ch] 
00000033  call        76AF49F0 
00000038  nop 
        }
00000039  nop 
        {
0000003a  nop 
            new StringBuilder();
0000003b  mov         ecx,79B9FB78h 
00000040  call        FD95FB90 
00000045  mov         dword ptr [ebp-40h],eax 
00000048  mov         ecx,dword ptr [ebp-40h] 
0000004b  call        76ACF938 
00000050  nop 
        }

我对此的解释是"new X()"计算为两个单独的调用。 第一个调用可能是"内存分配",而第二个调用是对象的构造函数。 我这样说是因为两个语句调用的第一个方法是相同的(即使它们是不同的类型),并且每种情况下的第二个调用都是不同的。

如果有人知道如何验证这些特定地址的评估结果,我很想知道。