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的单例是什么导致链接错误?
基础教程推荐
猜你喜欢
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- CString 到 char* 2021-01-01
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
- 初始化列表*参数*评估顺序 2021-01-01
