堆栈跟踪跳过一个方法?

Rya*_*ter 1 .net c# reflection exception-handling stack-trace

我有一个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 );
    }
}
Run Code Online (Sandbox Code Playgroud)

Jon*_*eet 5

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

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