故障转储完成通知
我强行使进程崩溃并尝试分析故障转储。 我面临着进程崩溃和崩溃转储生成(刷新)之间的竞争条件。
如果故障转储太大,那么需要一些CPU时间,Windows调试器(或watson)中是否有任何回调函数可以告诉故障转储完成情况?
或者是否有任何机制可以强制刷新故障转储并开始分析。
我不是在寻找基于民意调查的解决方案。
I am forcibly crashing the process and trying to analyze the crash dump.
I am facing the race condition between crash the process and crash dump generation (flush).
If the crash dump is too big then it takes some cputime, is there any callback function in windows debugger (or watson) which can tell about the crash dump completion?
Or is there any mechanism through which I can flush the crash dump forcibly and start analysis.
I am not looking for poll based solution.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
3a) 找到werfault.exe进程并
3b) 加入该进程(等待其完成)
步骤 3b 不使用轮询。进程是一个收到信号的同步对象。
请注意,步骤 3a 在崩溃之前不会起作用,如果崩溃转储很小,werfault.exe 可能已经退出,因此它可能会永远等待。要绕过此问题,您可能需要将应用程序注册为 werfault.exe 的调试器,该调试器在内部将参数转发到 werfault.exe,然后等待其完成。
完整的序列如下所示:
4a) 启动 werfault.exe 创建转储并
4b) 加入该进程(等到它完成)
最后,我想说您可以通过一些实施工作来实现您的目标。问题是:这将节省多少秒以及实施需要多少小时?
3a) finds werfault.exe process and
3b) join on that process (wait until it completes)
Step 3b does not use polling. A process is a synchronization object which gets signaled.
Note that step 3a will not work before crashing and if the crash dump is small, werfault.exe may already have exited, so it might wait forever. To bypass this, you might want to register your application as the debugger for werfault.exe, which internally forwards the arguments to werfault.exe and then waits until it completes.
The complete sequence then looks like this:
4a) Start werfault.exe to create the dump and
4b) join on that process (wait until it completes)
Finally I would say you can achieve your goal with some implementation effort. The question is: how many seconds will this save and how many hours will you need for implementation?