详情请见看雪论坛上 bookworm 大牛的讲解:http://bbs.pediy.com/showthread.php?threadid=30058php
一、DllMain中不能够作的事情:api
- CreateProcess / CreateThread
- GUI API (载入gdi32.dll或user32.dll)
- Registry API (advapi32.dll)
- CoInitiaklize(Ex), CoUnInitialize (ole32.dll)
- malloc / calloc / free (msvcrt.dll)
- GetModuleFileName, GetModuleHandle, 等等:尽管它们不载入DLL,但会引发系统产生一个Lock,所以有可能产生死锁(deadlock)。
- ExitThread:若是你在DllMain里调用它,则会再次进入DllMain,你固然明白这意味着什么。
- I/O(输入输出)函数,可能会引发等待。
二、能够作的事情:数据结构
- 初始化全局变量和全局数据结构
- 初始化CriticalSection
- TLS API: alloc/set/get/free
- Win32 内存管理API:Virtualxxx / Heapxxx,仅仅限于使用进程的堆(heap)
- CreateFile / ReadFile / WriteFile等等