当前位置:  开发笔记 > 编程语言 > 正文

附加.net调试器,同时仍然提供有用的死亡日志记录

如何解决《附加.net调试器,同时仍然提供有用的死亡日志记录》经验,为你挑选了1个好方法。

我想在我的代码的根目录中使用某种catch-all异常机制,因此当应用程序意外终止时,我仍然可以提供一些有用的日志记录.

有点像

static void Main () {
    if (Debugger.IsAttached)
        RunApp();
    else {
        try {
            RunApp();
        }
        catch (Exception e) {
            LogException(e);
            throw;
        }
    }
 }

虽然这一切都运行正常,但我的问题是当我想在引发异常后附加调试器时.

由于异常会转移到运行时,因此窗口会提示附加visual studio,但由于已经重新抛出,因此堆栈中的所有本地和参数都已丢失.

有没有记录这些异常,同时仍提供附加调试器并保留所有有用信息的方法?



1> Leaf Garland..:

正如Paul Betts已经提到的,你可能最好使用AppDomain.UnhandledException事件而不是try/catch块.

在UnhandledException事件处理程序中,您可以记录/显示异常,然后提供调试选项,例如显示带有异常详细信息的表单以及忽略,调试或退出的按钮.

如果用户选择调试选项,请调用System.Diagnostics.Debugger.Break(),它允许用户使用仍然可用的完整调用堆栈附加他们想要的任何调试器.

显然,你可以为你知道你不会将调试器附加到的任何构建禁用此选项.

class Program
{
    static void Main()
    {
        AppDomain.CurrentDomain.UnhandledException += ExceptionHandler;

        RunApp();
    }

    static void ExceptionHandler(object sender, UnhandledExceptionEventArgs e)
    {
        Console.WriteLine(e.ExceptionObject);
        Console.WriteLine("Do you want to Debug?");
        if (Console.ReadLine().StartsWith("y"))
            Debugger.Break();
    }

    static void RunApp()
    {
        throw new Exception();
    }
}

推荐阅读
个性2402852463
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有