当外部源代码中发生异常时,无法正确使用自创建的小型转储文件的堆栈跟踪

Stacktrace of self created Minidump-File can't be used correctly, when the Exception occurred in foreign source code

本文关键字:创建 小型 跟踪 堆栈 文件 转储 源代码 外部 异常      更新时间:2023-10-16

当外部源代码中发生异常时,我无法分析我自己创建的小型转储文件的堆栈跟踪。

堆栈跟踪

堆栈跟踪比如下所示:

[Frames may be missing, no binary loaded for ForeignLib1.dll]   Annotated Frame
>   ForeignLib1.dll!00000000454fc028    Unknown No symbols loaded.

但应该看起来像:

ForeignLib1.dll!00000000454d1fe8    Unknown No symbols loaded.
>   MyDll.dll!get_modeldoc  C++ Symbols loaded.
...(about 75 further Entries)
ForeignExecutable.exe!000000014000f973  Unknown No symbols loaded.
kernel32.dll!00007ffbae331fe4   Unknown Non-user code. Symbol loading disabled by Include/Exclude setting.
ntdll.dll!00007ffbaf07f061  Unknown Non-user code. Symbol loading disabled by Include/Exclude setting.

我的应用程序是一个 DLL,它加载在外部可执行文件中。我无法获得此可执行文件的 PDB 文件,因此无法加载 ForeignLib1.dll 库的符号...

小型转储

我创建了具有以下标志的小型转储:

MINIDUMP_TYPE mdt = (MINIDUMP_TYPE)(
MiniDumpWithDataSegs |
MiniDumpWithHandleData |
MiniDumpWithFullMemoryInfo |
MiniDumpWithThreadInfo |
MiniDumpWithUnloadedModules |
MiniDumpWithCodeSegs
);

回调例程包括以下类型:

IncludeModuleCallback
IncludeThreadCallback
ModuleCallback //(MyDll.dll and all ForeignLib-Dlls)
ThreadCallback
ThreadExCallback

DMP 文件是使用 MiniDumpWriteDump(...( 创建的

// generate the crash dump
BOOL result = MiniDumpWriteDump( hProc, procID, hFile,
mdt, sehPtr, NULL, &mci );

当源代码中出现异常时,我可以通过加载 PDB 文件来分析堆栈跟踪:

//MySource.cpp
int a = 0;
int b = 5 / a; // Exception, but Stack Trace can be analysed in DMP-File.

但是,当异常发生在由我的源代码调用的外部源代码中时,我只能在堆栈跟踪中看到外部 dll:

//MySource2.cpp
foreignModul->EnumDocuments2( nullptr ); // Exception, Stack Trace can't be analysed in DMP-File!!

问题

如何编写具有正确堆栈跟踪的 DMP 文件,或者在外部源代码中发生异常时如何分析堆栈跟踪?

我自己找到了解决方案。如果你有来自Minidump的确切的ForeinLib1.dll(二进制相等(,则可以在Visual Studio中分析堆栈跟踪:

  1. 右键单击卸载的 DLL,然后选择"加载符号" VS-屏幕截图加载符号

  2. 在文件浏览对话框中选择 DLL 文件(它必须等于小型转储中的二进制文件(。

  3. Visual Studio在新的File-Browse-Dialog中请求PDB文件。只需取消此内容即可。 VS-屏幕截图取消 PDB 选择

  4. Visual Studio现在需要一些时间来分析DLL文件(50mb文件大约需要2分钟(。

  5. 堆栈跟踪现已完成,或者您必须加载下一个"已卸载"DLL 文件。