可以从Windows SEH异常解码C异常吗? (如果是,怎么样?)

前端之家收集整理的这篇文章主要介绍了可以从Windows SEH异常解码C异常吗? (如果是,怎么样?)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果出现未处理的C异常,我想打印:

>消息(what())的C异常
>堆栈跟踪.

为了获取堆栈跟踪,我使用SetUnhandledExceptionFilter与StackWalker库结合使用:

  1. struct FooStackWalker : StackWalker
  2. {
  3. virtual void OnCallstackEntry(CallstackEntryType,CallstackEntry &entry) override
  4. {
  5. std::cerr << entry.lineFileName << " (" << entry.lineNumber << "): " << entry.undFullName << std::endl;
  6. }
  7. };
  8.  
  9. LONG WINAPI UnhandledExceptionHandler(LPEXCEPTION_POINTERS pointers)
  10. {
  11. FooStackWalker walker;
  12. walker.ShowCallstack(::GetCurrentThread(),pointers->ContextRecord);
  13. ::TerminateProcess(::GetCurrentProcess(),1);
  14. }
  15.  
  16.  
  17. int main()
  18. {
  19. ::SetUnhandledExceptionFilter(UnhandledExceptionHandler);
  20. }

我已经得到堆栈跟踪打印很好,但现在得到什么困难.

有一些方法可以将SEH异常解码为C异常,以便在终止之前调用此成员函数

为什么不使用已经给你异常细节的C机器?它不是排他性的SEH过滤器(虽然它是独家的SetUnhandledExceptionFilter).你只需要正确地嵌套处理程序:
  1. int main()
  2. {
  3. try {
  4. return cppexcept_main();
  5. }
  6. catch (const std::exception& e)
  7. {
  8. //use e.what()
  9. }
  10. }
  11.  
  12. int cppexcept_main()
  13. {
  14. __try {
  15. return application_main();
  16. }
  17. __except(GrabStackTrace(GetExceptionInformation()),EXCEPTION_CONTINUE_SEARCH) {
  18. /* never reached due to EXCEPTION_CONTINUE_SEARCH */
  19. }
  20. }

猜你在找的Windows相关文章