MFC应用程序关闭后异常中断

MFC应用程序关闭后异常中断,第1张

我测试了一下,release编译,即使空内容获取也没有问题。

我觉得,应该是你的项目中release版本的优化做的太多,或者程序其它原因造成的。

因为版本和环境差异,建议你自己先试验一下:

建立一个类似的mfc对话框工程,简单一个按钮一个编辑框,使用以上代码,release编译,看看有没有问题,如果没有,对比一下release版本的优化参数有什么不同(有就调整),如果没有不同,那么应该是你程序其它代码干扰的问题了,这种干扰问题很麻烦,只能是熟悉代码的情况下进行分析优化,没有太好的建议。

在App类里面定义一个未处理异常的回调函数。例如:

static LONG ApplicationCrashHandler(EXCEPTION_POINTERS* pException)

然后在这个函数里面实现计算机重启的功能。代码你可以自己在网上查询。这里我把提权限和重启的参考代码附上:

   OSVERSIONINFO os

    os.dwOSVersionInfoSize = sizeof(OSVERSIONINFO)

    GetVersionEx(&os)

    if (VER_PLATFORM_WIN32_NT == os.dwPlatformId)

    {

        HANDLE handle

        TOKEN_PRIVILEGES tkp

        OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &handle)

        LookupPrivilegeValue(NULL, SE_SHUTDOWN_NAME, &tkp.Privileges[0].Luid)

        tkp.PrivilegeCount = 1

        tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED

        AdjustTokenPrivileges(handle, FALSE, &tkp, 0, (PTOKEN_PRIVILEGES)NULL, 0)

        if (GetLastError() != ERROR_SUCCESS)

        {

            MessageBox(NULL, TEXT("AdjustTokenPrivileges error"), TEXT("error"), MB_OK | MB_ICONERROR)

        }

    }

    ExitWindowsEx(EWX_REBOOT, 0)

在App类的InitInstance成员函数的前面加上下列语句:

SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)App)

这个函数的功能是在整个进程出现了未处理异常的时候,就会把他交给ApplicationCrashHandler来处理,这个函数里面我们是做了重启 *** 作,因而能达到程序崩溃后能重启计算机的目的。

上面是在目标进程中来实现程序崩溃后重启计算机的,不需要另外单独写一个监控程序。如果需要单独写监控程序来做一个守护进程,可以用进程快照或者枚举进程来实现,这种做法缺点是用户更改了程序名就会出现问题,更好的做法是用内核对象来实现,在目标进程中申请一个内核对象,监控进程中打开这个内核对象,如果能打开就说明目标进程存在,否则表示不存在目标进程,就可以重启计算机了。这种做法记得在程序异常的时候关闭内核对象,否则当程序崩溃的时候,d出了标准的异常对话框,内核对象的生存周期还在,就无法达到程序崩溃的时候重启计算机了。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12141942.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-21
下一篇2023-05-21

发表评论

登录后才能评论

评论列表(0条)

    保存