【发布时间】:2011-01-13 16:27:47
【问题描述】:
我正在开发一个 Windows Phone 应用程序。 我将它提交给 Microsoft,他们给我发回了一个文件,描述了在恢复应用程序时发生的错误(它与 5.2 性能和资源管理,第 5.2.3 点有关)。
为了重现错误,我运行了应用程序,我从开始按钮开始转到“桌面”并单击“返回”按钮。
之后,Visual Studio 以黄色突出显示此代码中的 System.Diagnostics.Debugger.Break(); 行
// Code to execute on Unhandled Exceptions
private void Application_UnhandledException(object sender, ApplicationUnhandledExceptionEventArgs e)
{
if (System.Diagnostics.Debugger.IsAttached)
{
// An unhandled exception has occurred; break into the debugger
System.Diagnostics.Debugger.Break();
}
}
通过stacktrace,我发现最后调用的方法是CallApplicationUEHandler。
那么,这是一个已知的例外吗?我是不是忘了处理一些异常?
下面是 CallApplicationUEHandler 调用上方的最后三行输出:
first chance exception 'System.ArgumentNullException' in Microsoft.Phone.Controls.dll
first chance exception 'System.ArgumentException' in System.Windows.dll
first chance exception 'System.ArgumentException' in System.Windows.dll
构造函数:
对于主页:
public MainPage()
{
journal.Debug(string.Format("Entrée méthode {0}", new StackTrace().GetFrame(1).GetMethod().Name));
InitializeComponent();
Loaded += new RoutedEventHandler(PhoneApplicationPage_Loaded);
}
private void PhoneApplicationPage_Loaded(object sender, RoutedEventArgs e)
{
mainVM = new MainViewModel();
DataContext = mainVM;
}
对于应用程序:
public App()
{
// Global handler for uncaught exceptions.
// Note that exceptions thrown by ApplicationBarItem.Click will not get caught here.
UnhandledException += Application_UnhandledException;
// Standard Silverlight initialization
InitializeComponent();
// Phone- {2} -specific initialization
InitializePhoneApplication();
}
private void Application_UnhandledException(object sender, ApplicationUnhandledExceptionEventArgs e)
{
if (System.Diagnostics.Debugger.IsAttached)
{
// An unhandled exception has occurred; break into the debugger
System.Diagnostics.Debugger.Break();
}
}
【问题讨论】:
-
CallApplicationUEHandler是最重要的,因为这会触发未处理异常处理程序的事件链。堆栈跟踪的 rest 是什么?堆栈下方的内容将为我们提供更多信息以帮助您。有没有更详细的InnerException? -
@John Gardner:我下面什么都没有。但最后三个调试行包含第一次机会异常。我编辑了帖子以显示它们。
-
在您第一次离开之前,您能否确认该应用已完成完全加载?
-
我收到了同样的错误消息。使我抓狂。在我的情况下,应用程序有时无法启动。
标签: windows-phone-7 exception tombstoning