1

我有一个Foo方法类SomeMethod()。在SomeMethod()中,我运行:Bar bar = new Bar(); bar.BBQ();。在其中BBQ(),我调用了Name(n)引发消息异常的私有方法new StackTrace().GetFrame(n).GetMethod().Name

我的意图是将 1 传递给 Name(n),以便它返回值“BBQ”。但是,Name(0) 返回“Name”,而 Name(1) 返回“SomeMethod”。在引发异常的堆栈跟踪中,它也读起来好像 Name 是由 SomeMethod 直接调用的(没有提到 BBQ)。

有没有解决的办法?有谁知道可能导致此错误的原因是什么?是否有更好的方法来完成从 Name 获取值“BBQ”?

[TestClass]
public class Foo
{
    public Foo()
    {
    }
    [TestMethod]
    public void SomeMethod()
    {
        Bar bar = new Bar();
        bar.BBQ();
    }
}

public class Bar
{
    public Bar()
    {
    }
    public void BBQ()
    {
        Name( 1 );
    }
    private void Name( int n )
    {
        throw new Exception( new StackTrace().GetFrame(n).GetMethod().Name );
    }
}
4

1 回答 1

5

我强烈怀疑问题在于 JIT 编译器正在内联该方法。您可能可以通过在调试器中运行调试版本来验证这一点,并查看是否可以解决问题。

您可以相对容易地获得立即调用方法,但我相信在非调试器环境中获得完全准确的堆栈跟踪是不可行的。毕竟,您不想禁用内联。

于 2012-06-16T18:51:44.210 回答