1.shared_ptr对象创建方法
通常我们有两种方法去初始化一个std::shared_ptr
①通过它自己的构造函数
②通过std::make_shared
2.这两种方法都有哪些不同的特性呢?
shared_ptr是非侵入式的,即计数器的值并不存储在shared_ptr内,它其实是存在在其他地方——在堆上的,当一个shared_ptr由一块内存的原生指针创建的时候(原生内存:代指这个时候还没有其他shared_ptr指向这块内存),这个计数器也就随之产生,这个计数器结构的内存会一直存在——直到所有的shared_ptr和weak_ptr都被销毁的时候,这个时候就比较巧妙了,当所有shared_ptr都被销毁时,这块内存就已经被释放了,但是可能还有weak_ptr存在——也就是说计数器的销毁有可能发生在内存对象销毁后很久才发生
class Object
{
private:
int value;
public:
Object(int x = 0):value(x) {}
~Object() {}
void Print() const {cout << value << endl; }
};
int main()
{
std::shared_ptr<Object> op1(new Object(10)); //①
std::shared_ptr<Object> op2 = std::make_shared<Object>(10); //②
return 0;
}
3.这两种创建方式有什么区别?
答案:当使用第①种方式,op1有三个成员,op1._Ptr、op1._Rep、op1._mD,op1.
本文探讨了C++中shared_ptr的两种初始化方式:直接构造和使用make_shared。make_shared在内存分配上更高效,能提高Cache局部性,并在异常安全性和内存管理上具有优势。然而,它可能遇到目标类型构造限制和内存生存期问题。shared_ptr的引用计数结构在对象析构后仍会存在,直到所有weak_ptr被销毁。
最低0.47元/天 解锁文章

3万+

被折叠的 条评论
为什么被折叠?



