C++ shared_ptr based singletone what causes link error?(基于C++Shared_PTR的单例是什么导致链接错误?)
本文介绍了基于C++Shared_PTR的单例是什么导致链接错误?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
所以我尝试以下代码:
#ifndef TRANSMITTER_H
#define TRANSMITTER_H
class connector
{
public:
static boost::shared_ptr<connector> Instance(){
if(!instance)
{
instance = boost::shared_ptr<connector>(new connector());
}
return instance;
}
private:
connector(){}
static boost::shared_ptr<connector> instance;
};
#endif //TRANSMITTER_H
但获取链接错误:
Error 3 error LNK2001: unresolved external symbol "private: static class boost::shared_ptr<class connector> connector::instance" (?instance@0V?$shared_ptr@Vconnector@@@A)
我想退还的Shared_PTR有什么问题?是否应将其设置为函数作用域静态变量?
推荐答案
此
static boost::shared_ptr<connector> instance;
在类定义中只有一个声明。您似乎没有它的定义。此定义位于类定义之外。
但是,您可能更愿意这样做:
class connector
{
public:
connector(connector const&) = delete;
connector& operator=(connector const&) = delete;
static boost::shared_ptr<connector> Instance()
{
static boost::shared_ptr<connector> instance (new connector);
return instance;
}
private:
connector(){}
};
在本例中instance
被定义为Instance
的内联函数定义中的静态函数局部对象。它的好处在于,这种初始化在C++11中保证是线程安全的。
这篇关于基于C++Shared_PTR的单例是什么导致链接错误?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:基于C++Shared_PTR的单例是什么导致链接错误?
猜你喜欢
- OpenGL 对象的 RAII 包装器 2021-01-01
- GDB 不显示函数名 2022-01-01
- 如何提取 __VA_ARGS__? 2022-01-01
- 使用 __stdcall & 调用 DLLVS2013 中的 GetProcAddress() 2021-01-01
- XML Schema 到 C++ 类 2022-01-01
- 从父 CMakeLists.txt 覆盖 CMake 中的默认选项(...)值 2021-01-01
- DoEvents 等效于 C++? 2021-01-01
- 将函数的返回值分配给引用 C++? 2022-01-01
- 将 hdc 内容复制到位图 2022-09-04
- 哪个更快:if (bool) 或 if(int)? 2022-01-01