如何解决VC中的警告Warning C4251
2011-09-16 09:28
253 查看
这通常是由于以数据成员方式在DLL导出类中使用了模板类造成的。比如:
#include <iostream>
#include <vector>
using namespace std;
class __declspec( dllexport ) Test
{
public:
std::vector<int> m_objCon;
};
int main()
{
return 0;
}
这会导致这个警告:
warning C4251: “Test::m_objCon”: class“std::vector<_Ty>”需要有 dll 接口由 class“Test”的客户端使用
1> with
1> [
1> _Ty=int
1> ]
这个问题主要要描述的是不同的地方的vector的实现可能不一样所造成的问题。所以我们应该将其导出。有很多方法可以解决这个问题的。
第一种: 无视它或者#pragma warnind( disable: 4251 )
第二种:将该数据改为指针方式:
class __declspec( dllexport ) Test
{
public:
std::vector<int>* m_objCon;
};
然后在构造函数和析构函数中分别初始化和释放它。
第三种:
将该模板类及其依赖类导出。
#include <iostream>
#include <vector>
using namespace std;
class __declspec( dllexport ) Test
{
public:
template class __declspec( dllexport ) std::allocator<int>;
template class __declspec( dllexport ) std::vector<int, std::allocator<int> >;
public:
std::vector<int> m_objCon;
};
int main()
{
return 0;
}
这种方法要注意的是必须要把要导出模板类的模板数据成员一并导出。有点类似于显式实例化。比如说你要导出boost::shared_ptr就还必须将其依赖的shared_count一并导出。导出map还需要导出对应pair等等。很麻烦啦~所以我们还是选择第四种吧。
第四种:Impl。
#include <iostream>
#include <vector>
using namespace std;
// 这些放到.h中
class Test_imp;
class __declspec( dllexport ) Test
{
// 构造函数中初始化 析构中释放m_pImp;
void test();
public:
Test_imp* m_pImp;
};
// 这个类放到cpp中去
class Test_imp
{
public:
void test(){}
std::vector<int> m_objCon;
};
// 放到cpp中
void Test::test()
{
m_pImp->test();
}
int main()
{
return 0;
}
个人推荐第二种和第四种,反对第一种。毕竟掩耳盗铃不是好习惯~~
#include <iostream>
#include <vector>
using namespace std;
class __declspec( dllexport ) Test
{
public:
std::vector<int> m_objCon;
};
int main()
{
return 0;
}
这会导致这个警告:
warning C4251: “Test::m_objCon”: class“std::vector<_Ty>”需要有 dll 接口由 class“Test”的客户端使用
1> with
1> [
1> _Ty=int
1> ]
这个问题主要要描述的是不同的地方的vector的实现可能不一样所造成的问题。所以我们应该将其导出。有很多方法可以解决这个问题的。
第一种: 无视它或者#pragma warnind( disable: 4251 )
第二种:将该数据改为指针方式:
class __declspec( dllexport ) Test
{
public:
std::vector<int>* m_objCon;
};
然后在构造函数和析构函数中分别初始化和释放它。
第三种:
将该模板类及其依赖类导出。
#include <iostream>
#include <vector>
using namespace std;
class __declspec( dllexport ) Test
{
public:
template class __declspec( dllexport ) std::allocator<int>;
template class __declspec( dllexport ) std::vector<int, std::allocator<int> >;
public:
std::vector<int> m_objCon;
};
int main()
{
return 0;
}
这种方法要注意的是必须要把要导出模板类的模板数据成员一并导出。有点类似于显式实例化。比如说你要导出boost::shared_ptr就还必须将其依赖的shared_count一并导出。导出map还需要导出对应pair等等。很麻烦啦~所以我们还是选择第四种吧。
第四种:Impl。
#include <iostream>
#include <vector>
using namespace std;
// 这些放到.h中
class Test_imp;
class __declspec( dllexport ) Test
{
// 构造函数中初始化 析构中释放m_pImp;
void test();
public:
Test_imp* m_pImp;
};
// 这个类放到cpp中去
class Test_imp
{
public:
void test(){}
std::vector<int> m_objCon;
};
// 放到cpp中
void Test::test()
{
m_pImp->test();
}
int main()
{
return 0;
}
个人推荐第二种和第四种,反对第一种。毕竟掩耳盗铃不是好习惯~~
相关文章推荐
- 如何解决VC中的警告Warning C4251--- 转载
- 如何解决VC中的警告Warning C4251
- 如何解决VC中的警告warning C4251 needs to have dll-interface
- 【VC编译问题】如何解决VC中的警告Warning C4251
- 如何解决VC中的警告Warning C4251
- 如何解决VC中的警告warning C4251 needs to have dll-interface
- 如何解决Android 5.0中出现的警告:Service Intent must be explicit
- 如何解决VC自动成员功能失效
- 如何解决Android 5.0中出现的警告:Service Intent must be explicit
- 如何解决警告linking against dylib not safe for use in application extensions
- Visual Studio 2013 配置Boost库。 如何编译和选择,遇到无法打开文件“libboost_thread-vc120-mt-gd-1_58.lib的解决办法
- 如何解决Android 5.0中出现的警告:Service Intent must be explicit
- VC++ 如何隐藏使用STL而带来的大量警告
- 如何解决Android 5.0中出现的警告:Service Intent must be explicit
- 如何在VC代码里添加TODO编译警告
- VC 获取网页数据时,如何解决乱码问题
- 如何解决Android 5.0中出现的警告:Service Intent must be explicit
- [原创].如何解决Nios II SBTE中出现的undefined reference to `xxx'警告
- vs2010安装完vc助手之后字体变成斜体如何解决?
- 如何解决"MSVCRED" conflicts的编译警告?