gpt4 book ai didi

c++ - LNK 2022 : Inconsistent layout information, 迁移到VS2010后

转载 作者:太空狗 更新时间:2023-10-29 21:02:19 26 4
gpt4 key购买 nike

我有一个 VS2010 解决方案,其中包含(除其他外)以下项目:

  • Native.DLL(静态链接到第三方库 ITK 的 native C++ 项目,其中包括 STL)

伪代码(非常简化):

using namespace std;

bool Native::CalcSomething(double* result, string& errorMsg);
  • Wrapper.DLL(动态链接到 Native.DLL 并在调用 Native.DLL 时使用 std:string 的 C++/CLI 项目)

伪代码(非常简单)

bool Wrapper::WrappedCalcSomething([System::Runtime::InteropServices::OutAttribute] double[] result,[System::Runtime::InteropServices::OutAttribute] System::String^ errorMsg)
{
Native* ntv = new Native();

std:string error;
pin_ptr<double> resultPtr = &result[0];

bool success = ntv->CalcSomething(resultPtr, error);

errorMsg = gcnew System::String(error.c_str());

return success;
}

这在 VS2008 (x64) 中编译和链接完美,但在迁移到 VS2010 后(由于各种原因),链接器给出以下错误:

2>  Generating Code...
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.logic_error): (0x02000049).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.domain_error): (0x0200004a).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.invalid_argument): (0x0200004b).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.length_error): (0x0200004c).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.out_of_range): (0x0200004d).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.runtime_error): (0x0200004e).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.overflow_error): (0x02000050).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.underflow_error): (0x02000051).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std.range_error): (0x02000052).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std._Locinfo): (0x02000054).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (_Locimp): (0x02000059).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (failure): (0x02000068).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std._String_val<char,std::allocator<char> >): (0x02000097).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (std._String_val<wchar_t,std::allocator<wchar_t> >): (0x02000099).
2>MSVCMRTD.lib(locale0_implib.obj) : error LNK2022: metadata operation failed (8013118D) : Inconsistent layout information in duplicated types (lconv): (0x020000ce).
2>LINK : fatal error LNK1255: link failed because of metadata errors

我已经阅读了几乎所有我能找到的关于这个问题的帖子,并尝试过:

  • 清理和重建
  • Move the headers around - 没有对 windows.h 的引用,我尝试移动 #include 行没有效果
  • Using the /clr flag only on the files that need it在 Wrapper.DLL 中(这恰好是项目中的所有文件)。问题在于 Native.DLL 中需要由 Wrapper.DLL 调用的公共(public)方法在其签名中包含一个 std:string 参数。这使得很难将 STL 引用从/clr 编译的范围中分离出来
  • 我正在编译所有内容(包括 ITK,第 3 方库)使用/MDd(并尝试过/MD)- 更改此设置似乎不会影响事情
  • 我没有看到任何地方使用 /Zp 或 pragma pack

我能想到的唯一“解决方案”是将 Native.DLL 中的方法更改为不使用 std:string 作为参数(例如,改用 char*)。然而,避免在任何 C++/CLI 包装器中使用 STL 似乎不是一个解决方案。 一定有更好的方法!

注意:我知道关于如何“调试”这些问题的文章 (link),但除非我弄错了,否则我想我知道问题的根源是 std:string。

最佳答案

我想通了。

我对其中一个 CMake 文件进行了语法更改,我认为它在功能上与之前发生的相同(本质上我使用的是 CMake 便利变量)。然而,这当然会产生意想不到的后果,并且生成的项目文件不一样。

具体来说,Wrapper.DLL 项目现在链接到它根本不需要链接到的第 3 方 ITK 库(只有 Native.DLL 需要这些)。

在改回 CMake 并正确生成项目后,可怕的 LNK2022 消失了。我只能怪我自己浪费了所有这些时间......

关于c++ - LNK 2022 : Inconsistent layout information, 迁移到VS2010后,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15745762/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com