0

当局部静态变量的初始化发生在使用参数 DLL_THREAD_DETACH 从 DLLMain 入口点调用的函数中时,我的应用程序中就会发生死锁。

下面是Windbg分析

这通常是由另一个持有加载程序锁的线程引起的。

以下是持有的锁。

CritSec ntdll!LdrpLoaderLock+0 at 7c97e178

锁数 3

递归计数 1

拥有线程 17e8

EntryCount d

争用计数 d

*** 锁定

CritSec MSVCR80!__app_type+94 at 781c3bc8

锁定计数 1

递归计数 1

拥有线程 1100

条目数 1

ContentionCount 1 *** 锁定

#

调用堆栈线程 17e8

781c3bc8 78132bd9 0777fde4 ntdll!RtlEnterCriticalSection+0x46

00000008 b87d2630 00000000 MSVCR80!_lock+0x2e

0864ae10 08631d7f 0864ae10 EPComUtilities32!_onexit+0x36

0864ae10 b87d2588 00000001 EPComUtilities32!atexit+0x9

0777fea8 0864719f 08630000 EPComUtilities32!XCriticalSectionEx::ThreadTerminated+0x5f

08630000 00000003 00000000 EPComUtilities32!DllMain+0x20

08630000 7c90118a 08630000 EPComUtilities32!__DllMainCRTStartup+0x7a

08630000 00000003 00000000 EPComUtilities32!_DllMainCRTStartup+0x1d

#

调用堆栈线程 1100

000000b0 00000000 00000000 ntdll!ZwWaitForSingleObject+0xc

000000b0 ffffffff 00000000 kernel32!WaitForSingleObjectEx+0xa8

000000b0 ffffffff 06ce64e0 kernel32!WaitForSingleObject+0x12

000480ba 000f4240 00000000 CATSysMultiThreading!CATThreads::Join+0xf5

0012fcc8 00000004 00000000 JS0GROUP!CATLM::StopHB+0xf4

d138509f 00416694 00000001 JS0GROUP!CATLM::Unmake+0x6b

00000000 00000000 00000000 MSVCR80!_cinit+0xd6

00000000 0012fd6c 081e68d9 MSVCR80!exit+0xd

00000000 06d404f0 0998fb90 JS0GROUP!CATExit+0x1d

00000000 004ef366 0000000d DNBPLMProvider!DNBEPLMTransactionMgt::OnApplicationExit+0x229

00000000 0012fd9c 004eabfc JS0GROUP!CATCallExits+0x2bc

00000000 0012ff7c 0040cefd JS0GROUP!CATErrorNormalEnd+0x31 00000000 06ce71d0 06ce71d0 JS0GROUP!CATExit+0xc

00000007 06cdb120 059b61d8 DLMMfgContextSolver!main+0x146d

ffffffff ffffffff bffde000 DLMMfgContextSolver!__tmainCRTStartup+0x10f

#

请给您评论以了解可能导致死锁的原因。注意:当我将静态变量设为非静态时,问题在论坛中发布的示例上下文中消失了死锁发生在函数作用域静态变量中(VC++ 中的线程不安全)

4

1 回答 1

0

简而言之,导致僵局的原因是您在 DllMain 中做了一些不平凡的事情

于 2010-03-01T11:08:48.910 回答