为什么我的程序在拥有线程的情况下生成LdrpLoaderLock死锁
Why does my program generate LdrpLoaderLock deadlock with owning thread?
我开发了一个已经工作多年的c++应用程序。我们最近在测试实验室增加了一些4台处理器测试机。
之后,我们发现负载下的特定测试会间歇性地导致LdrpLoaderLock
死锁,而拥有线程不再运行。拥有线程id通常是从运行线程推断出的可能的线程id,并且锁内存结构看起来不会损坏。
我在调试器中没有遇到此问题。我只是能够在它发生之后再看它。我开始记录我正在创建的所有线程,但我在那里没有看到问题线程id。不过,这可能没有意义,因为死锁发生后,日志记录可能无法工作。我想我需要一种跟踪线程创建和入口点的方法,这样我就可以知道是哪个线程在做这件事。感谢您的帮助。
来自windbg
0:000>!锁定CritSec ntdll!Ldrp装载机锁定+0,775d20c0WaiterWoken否锁定计数5递归计数2拥有线程f38入口计数0内容计数5***锁定
扫描805个关键部分
0:000>!螺纹指数TID0 00000 ab8100000 8cc20万e683 0000134c400000c445 0000113060万f1870000009088 0000108490000000 f0810 0000109811 000010101200万d4013 0000135c
线程堆栈消耗的VM总数0x031cf000
0:000>d 775d20c0775d20c0 60 43 5d 77 ea-fff ff-02 00 00 00 38 0f 00 00 `C]w。。。。。。。。8.775d20d0 ac 04 00 00 00 00 00-40 43 5d 77 ff ff ff ff@C] w。。。。775d20e00 00 00 00 000 00 00 00-00 00 00 00 02。。。。。。。。。。。。。。。。775d20f00 00 00 00 000 00 00 00-00 00 00 00。。。。。。。。。。。。。。。。775d2100 00 49 5d 77 ff ff ff ff-00 00 00 00 00 00.I]w。。。。。。。。。。。。775d2110 00 00 00 00 000 00 00-00 00 00 00。。。。。。。。。。。。。。。。775d2120 20 49 5d 77 ff ff ff ff-00 00 00 00 00 00I]w。。。。。。。。。。。。775d2130 00 00 00 00 a0 0f 00 00-00 00 00 00
Raymond Chen是正确的。我正在调用第三方com组件。它创建了一个线程,然后在析构函数中调用TerminateThread。幸运的是,我有一个源代码许可证,否则我将永远不知所措。注释掉那个析构函数中的TerminateThread调用并重新构建解决了我的问题。现在让第三方修复他们的代码。
相关文章:
- 在没有太多条件句的情况下,我如何避免被零除
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 在未初始化映射的情况下,将值插入到映射的映射中
- 是默认情况下分配给char数组常量的值
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 如何在不产生任何垃圾的情况下获得C中的像素
- 在已经使用Git的情况下减少编译时间
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- 如何在没有信号的情况下从C++执行QML插槽
- 如何在不知道向量大小的情况下输入向量内部的向量?
- 为什么在某些情况下不写入此文件?
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 在没有Xcode的情况下在Mac捆绑包中嵌入框架
- UE4-如何在给定4个屏幕坐标的情况下缩放纹理或材质
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 在C++中如何在没有pow的情况下进行基础计算
- 松弛原子与无同步情况下的记忆连贯性
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 我是c ++的新手,你能解释一下在这种情况下的指针吗
- 在没有参数列表的情况下使用模板名称"Event"无效,模板问题