一张图系列——为什么在DllMain里面创建了线程并Wait会卡死
2016-04-20 12:44
393 查看
这是一个老话题了,推荐一篇文章:
http://blog.csdn.net/breaksoftware/article/details/8150476#0-tsina-1-83826-397232819ff9a47a7b7e80a40613cfe1
这里简单画图阐述核心问题所在:
关键在于ntdll!LdrpLoaderLock这把锁。
1、在使用DLL_PROCESS_ATTATCH进入DllMain之前当前线程会获取这把锁。
2、如果在DllMain里面创建了线程,新线程初始化过程中也会去获取这把锁。
3、如果仅仅CreateThead就返回后,当前线程就很快释放该锁,随后新创建的线程也能顺利的获取到该锁。
4、但如果CreateThread之后使用了Wait等待该线程结束,那当前线程没有释放LdrpLoaderLock,新线程又获取不到,进入等待。就会导致卡死。
所以,最好别在DllMain中创建线程,即使创建了也千万别等待。
最后,一张图看清个中关系(图片右键新标签页打开可看完整高清大图):
http://blog.csdn.net/breaksoftware/article/details/8150476#0-tsina-1-83826-397232819ff9a47a7b7e80a40613cfe1
这里简单画图阐述核心问题所在:
关键在于ntdll!LdrpLoaderLock这把锁。
1、在使用DLL_PROCESS_ATTATCH进入DllMain之前当前线程会获取这把锁。
2、如果在DllMain里面创建了线程,新线程初始化过程中也会去获取这把锁。
3、如果仅仅CreateThead就返回后,当前线程就很快释放该锁,随后新创建的线程也能顺利的获取到该锁。
4、但如果CreateThread之后使用了Wait等待该线程结束,那当前线程没有释放LdrpLoaderLock,新线程又获取不到,进入等待。就会导致卡死。
所以,最好别在DllMain中创建线程,即使创建了也千万别等待。
最后,一张图看清个中关系(图片右键新标签页打开可看完整高清大图):
![](https://images2015.cnblogs.com/blog/659280/201604/659280-20160420124319038-697357804.png)
相关文章推荐
- Trie图和Fail树
- Contains Duplicate
- [AIR] 打包生成APK的命令行
- Linux 上使用 Gmail SMTP 服务器发送邮件通知
- Xcode模拟器出现installation failed invalid argument
- leetcode11.ContainerWithMostWater
- Exchange2010&2013与Exchange2016共存环境下的客户端访问
- leetcode 336. Palindrome Pairs
- Codeforces All-Ukrainian School Olympiad in Informatics F.Tourist
- 山东省第五届ACM省赛题——angry_birds_again_and_again(计算几何)
- [CareerCup] 17.3 Factorial Trailing Zeros 求阶乘末尾零的个数
- IDXGISwapChain接口
- 人工智能60年:机器审美观
- su: cannot set user id: Resource temporarily unavailable
- su: cannot set user id: Resource temporarily unavailable
- su: cannot set user id: Resource temporarily unavailable
- 山东省第五届ACM大学生程序设计竞赛 angry_birds_again_and_again 求积分
- JetBrains 加入 .NET 基金会
- 人工智能、大数据、金融和SaaS四大风口上看风向
- No grammar constraints (DTD or XML schema).....两种解决方法