Visual c++ 2008应用程序在链接时出现的名称混淆(declspec)不匹配的链接错误
Link error with name mangling declspec mismatch in Visual C++ 2008 application at link time
我有一个DLL和一个主可执行文件,主可执行文件不再链接DLL的导入库中的符号,DLL .map文件中的declspec不匹配,也不匹配破损的c++名称。我不明白为什么,虽然我做了通常的事情你做当你不能得到c++的东西链接。
我的头文件定义如下:
#ifdef MY_MODULE
#undef CLASS_EXPORT
#define CLASS_EXPORT __declspec(dllexport)
#else
#undef CLASS_EXPORT
#define CLASS_EXPORT __declspec(dllimport)
#endif
我的类似乎导出正确,但.map文件表明一些奇怪的事情,我认为是错误的:
6 ?CreateDataArea@@YAKPAGPBD111PAVCObject@@K@Z (unsigned long __cdecl
CreateDataArea(unsigned short *,char const *,char const *,char const *,
char const *,class CObject *,unsigned long))
上面的名字有@@YAK...
链接错误是:
1>Device.obj : error LNK2019: unresolved external symbol
"__declspec(dllimport) public: unsigned long __thiscall
CCommonMemory::CreateDataArea(unsigned short *,char const *,char const *,
char const *,char const *,class CObject *,unsigned long)"
(__imp_?CreateDataArea@CCommonMemory@@QAEKPAGPBD111PAVCObject@@K@Z) referenced
in function "public: __thiscall CDevice::CDevice(void)" (??0CDevice@@QAE@XZ)
那么,当我配置declspec宏时,为什么损坏的名称@@QAEK
不同,为什么当宏定义__declspec(dllexport)
时,.map文件显示__thiscall
调用约定?
这就像我忘记做__declspec(dllimport/dllexport)宏一样,但我还是做了。
我试着把CLASS_EXPORT放在每个导出的方法上,我试着在类声明的第一行,没有改变。
看起来CreateDataArea()
的定义没有作用于类(即。(在定义函数时遗漏了一个CCommonMemory::
)。
如果您查看map文件中的内容,您将看到它是一个没有附加类名的__cdecl
函数
相关文章:
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- CMake-按正确顺序将项目与C运行时对象文件链接
- 从链接列表c++中删除一个项目
- 有根的二进制搜索树.保留与其父级的链接
- 读取文件的最后一行并输入到链接列表时出错
- 静态数据成员的问题-修复链接错误会导致编译器错误
- node-gyp 在 macOS 上未正确链接库
- 基于boost的程序的静态链接——zlib问题
- 无法链接 CMake 中的本地库
- 内联函数中具有内部链接的全局变量
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 使用gcc从静态链接的文件中查找可选符号
- 我可以将一个用clang c++11编译的对象与另一个用c++17编译的对象链接起来吗
- 将--whole archive链接器选项与CMake和具有其他库依赖项的库一起使用
- 下面是我为检测链接列表中的循环而制作的代码
- 有了gcc,是否可以链接库,但前提是它存在
- 使用C链接在函数内部创建C++模板
- Visual Studio mkl_link_tool.exe链接错误
- 尝试链接我的着色器时,我收到错误代码"error c5145 must write to gl_position"
- Visual c++ 2008应用程序在链接时出现的名称混淆(declspec)不匹配的链接错误