即使没有包装在外部"C"中,也会调用 DllMain() ?
DllMain() being called even when not wrapped in extern "C"?
在用C++(64位Windows)编写的DLL中,DllMain()
是否应该声明为使用C链接,即用extern "C" { }
包装?
据我所知,这个DllMain()
方法使用C++链接,但它被正确地调用了。
在的某个地方是否存在允许调用具有C++链接(因此名称有误)的DllMain()
方法的特殊情况?
操作系统不会直接调用代码的DllMain
函数()。DLL自己的RTL在内部调用它。RTL的真正入口点在DLL PE头中公开,这样操作系统就可以找到它。操作系统调用RTL的入口点,然后它调用代码的DllMain()
函数。DllMain()
的链接本身对操作系统并不重要,只对链接器重要。
APIENTRY就是这样做的。它可以归结为__stdcall。
有关__stdcall和APIENTRY的作用,请参阅MSDN文档?。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 函数调用中参数的顺序重要吗
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 在c++类上调用void函数
- 为什么 std::unique 不调用 std::sort?
- 调用专用模板时出错"no matching function for call to [...]"
- 选择要调用的构造函数
- C++为什么尽管我调用了void函数,它却不起作用
- 构造函数正在调用一个使用当前类类型的函数
- 变量没有改变?通过向量的函数调用
- 没有为自己的结构调用列表推回方法
- 在VC++中从DLLMAIN内部调用D3D的CREATEDEVICE时,它会创建一个死锁(loaderlock?)。有没有办法克服这个问题?最终目标内
- 在 DLLMAIN() 中调用函数
- 正在从DLLMain调用托管代码
- 即使没有包装在外部"C"中,也会调用 DllMain() ?
- 如何在64位窗口中以编程方式模拟DllMain调用