继上文说到使用 IDA 和 WinDbg 调试无 dmp 文件
那么在有源码的情况下可以直接断点调试 DLL,目的是查看 DLL 内部的函数调用
场景:
程序执行到某个 DLL 时突然崩溃,先确定 Debug 生成的 DLL 在程序中运行是否也会有闪退
如果有,则适用于 VS 断点调试
操作步骤:
在 Debug 下生成一个对应的 DLL
注意:必须是 Debug 生成的 DLL,不然没法断点
然后将 DLL 替换到崩溃程序的运行目录下,目的是崩溃程序运行时依赖的是 Debug 的 DLL
接着 VS 以 Debug 模式运行 DLL 的源码程序,并点击 Attach to Process
崩溃程序和 DLL 源码程序不是一回事,DLL 源码生成的 DLL 供崩溃程序使用的
选择要附加的进程,也就是我们之前运行的崩溃程序
确定 Attach 成功后,崩溃程序调用到 Debug 的 DLL 时就会停在我们预先打的断点上,通过断点我们就可以单步调试来查看函数调用以找出崩溃的地方
上面截图是 sentry-native 相关源码