DllMain函数不可做的几件事儿

详情请见看雪论坛上 bookworm 大牛的讲解:http://bbs.pediy.com/showthread.php?threadid=30058

 

1、DllMain中不可以做的事情:

  •     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(输入输出)函数,可能会引起等待。

2、可以做的事情:

  •     初始化全局变量和全局数据结构
  •     初始化CriticalSection
  •     TLS API: alloc/set/get/free
  •     Win32 内存管理API:Virtualxxx / Heapxxx,仅仅限于使用进程的堆(heap)
  •     CreateFile / ReadFile / WriteFile等等

你可能感兴趣的:(DllMain函数不可做的几件事儿)