Zac*_*tes 6 c# static nullreferenceexception visual-studio winforms
这个有点深奥.尝试在visual studio 2008中的winforms项目中打开表单(在winforms设计器中)时遇到了NullReferenceException.堆栈跟踪指向以下代码的第四行:
public static class Logger
{
public static void LogMethodEnter()
{
var frame = new StackFrame(1);
var method = frame.GetMethod();
Trace.TraceInformation("{0}.{1}.{2}()", method.DeclaringType.Namespace, method.DeclaringType.Name, method.Name);
Trace.Indent();
}
public static void LogMethodExit()
{
Trace.Unindent();
}
}
Run Code Online (Sandbox Code Playgroud)
...意思是开口大括号的线条.我在其他项目中遇到了同样的问题(但不涉及winforms设计器),我认为这是一个与线程相关的问题,但我没有代码来复制它.
为什么会发生这种情况,为什么异常堆栈跟踪指向带有花括号的行?
澄清:空引用异常仅发生在winforms设计器中.运行应用程序时,它不会抛出该错误.
我猜测行号已关闭(实际原因并不那么重要),并且该表达式实际上引发了异常:
method.DeclaringType.Namespace
Run Code Online (Sandbox Code Playgroud)
您可能会看到 NullReference 异常的原因是new StackFrame(1)前几行的表达式有时会返回空帧。空帧意味着调用.GetMethod()将返回 null,然后就可以了。
有时得到空帧的原因是即时编译器可以选择内联简短的、重复调用的方法,就像代码中的方法一样。这会抛出你的调用堆栈,所以最好的情况是你得到一个比你预期更高级别的方法,或者最坏的情况(在你的 Main 方法中)没有更高级别的方法并且你得到 null。