2、其次这个时候调试器这个地方会变成继续,看到黄色调试箭头。
3、最后在黄色箭头这个地方,也会变成相应的终止项,需要注意的是在这个过程中不要随意拖动这个黄色的调试箭头,不然的话程序会默认自动更新了代码会自动进入到调试中。
vs程序打开串口之后软件闪退的解决方法:1.断点调试。 2.记得多写日志。 3.线程崩溃会导致所在进程崩溃。4.单步跟踪,看到哪里闪退,查找代码问题 。5.在台式机上用原生的串口尝试,排除是否是笔记本USB转串口的兼容问题。
在App类里面定义一个未处理异常的回调函数。例如:
static LONG ApplicationCrashHandler(EXCEPTION_POINTERS* pException)然后在这个函数里面实现计算机重启的功能。代码你可以自己在网上查询。这里我把提权限和重启的参考代码附上:
OSVERSIONINFO osos.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出了标准的异常对话框,内核对象的生存周期还在,就无法达到程序崩溃的时候重启计算机了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)