1、unique_ptr 一个unique_ptr拥有它指向的对象的独占所有权,并且会在指针超出范围时销毁该对象。unique_ptr明确地阻止复制其包含的指针。不过可以使用std::move函数必须用于将包含的指针的所有权转移给另一个unique_ptr。示例代码 2、shared_ptr 引用计数的智能指针。当您想要将一个原始指针分配给多个所有者时使用...
unique_ptr:独占式指针,同一时刻只能有一个指针指向同一个对象。 shared_ptr:共享式指针,同一时刻可以有多个指针指向同一个对象,通过引用计数来管理对象的生命周期。 weak_ptr:弱指针,用来解决shared_ptr相互引用导致的死锁问题,它不能单独管理对象,只能从一个已存在的shared_ptr或weak_ptr创建,且不会增加对象的引...
};voidmy_deleter(Test* t){cout<<"worked"<<endl; }unique_ptr<int>cl1(intp){returnunique_ptr<int>(newint(p)); }unique_ptr<int>cl2(intp){unique_ptr<int>rt(newint(p));returnrt; }voidfl1(unique_ptr<int> p){ *p =100; }intmain(){//test1 不可以拷贝和赋值/* unique_ptr<int> ...
使用unique_ptr,只要unique_ptr指针创建成功,析构函数就一定会被调用,如下: voidfunc() { unique_ptr<int> uptr(newint(10));//maybe throw exception} 2.返回函数内动态申请资源的所有权 unique_ptr<int> func(intvalue) { unique_ptr<int> uptr(newint(value));returnuptr; }intmain() { unique_ptr<...
unique_ptr 在默认情况下和裸指针的大小是一样的。 所以 内存上没有任何的额外消耗,性能是最优的,我们大多数场景下用到的应该都是 unique_ptr。 shared_ptr 的内存占用是裸指针的两倍。因为除了要管理一个裸指针外,还要维护一个引用计数。因此相比于 unique_ptr, shared_ptr 的内存占用更高。在使用 shared_ptr...
C++中智能指针包括std::unique_ptr、std::shared_ptr和std::weak_ptr。它们通过管理对象的生命周期和引用次数来确保在适当的时间释放内存。例如,std::unique_ptr保证同一时间只有一个指针指向对象,并在指针离开作用域时自动删除所指向的对象,避免了内存泄漏。
shared_ptr weak_ptr 它们都在内存头文件中声明。 文章来源丨极客(geeksforGeeks) auto_ptr 从C ++ 11开始不推荐使用此类模板。unique_ptr是一种具有类似功能但具有改进的安全性的新功能。 auto_ptr是一个智能指针,用于管理通过新表达式获得的对象,并在销毁auto_ptr本身时删除该对象。
1. auto_ptr: c++11中推荐不使用他(放弃) 2.shared_ptr:拥有共享对象所有权语义的智能指针 3.unique_ptr:拥有独有对象所有权语义的智能指针 4.weaked_ptr:到std::shared_ptr所管理对象的弱引用 1.1 shared_ptr 参考:https://zh.cppreference.com/w/cpp/memory/shared_ptr ...
智能指针作为C++ 11中自动管理内存的重要工具,包括:std::unique_ptr、std::shared_ptr和std::weak_ptr等。C++ 20对这些智能指针做了进一步的优化和扩展,并引入了新的与内存管理和资源控制相关的功能。下面,我们对一些主要的优化点进行详细的介绍。 对unique_ptr的优化 ...
首先,对于智能指针,它是无法隐式构造的,不管是unique_ptr,还是shared_ptr,或者是weak_ptr。 即,如果想要初始化一个智能指针,得使用传入参数的形式: unique_ptr<int>up(newint); 为什么需要使用智能指针呢? 答:为了防止内存泄漏。很多情况下,程序员很容易忘记释放申请来的内存空间。比如说,在一个函数中使用new申...