shared_ptr 陷阱 / 缺点
引用计数:记的是有多少个智能指针,拥有某个内存的所有权。
举个例子:
auto sharedPtr = make_shared<Class>();
cout << sharedPtr.use_count()
输出为1, 表明对Class这个类的所有权拥有者只有1个。
不要把原生指针给多个shared_ptr管理
为什么可以用原生指针初始化shared_ptr, 再看下shared_ptr的构造函数:
同样的代码,智能指针管理对象就可以。
为什么不能管理原生指针呢?
因为,sharedPtr引用计数为0的时候会自动调用析构函数,对于原生指针,会析构相同的内存空间两次,因此会有问题!
修改的方式:
如果改成这个样子,就可以正常析构。因为sharedPtr_1的引用计数在初始化的自增1,在赋值的时候自增为2。sharedPtr2也是2. 这样就可以正常的析构。
所以这里要注意的是:sharedPtr的引用计数何时会