在上面的示例中,我们使用std::unique_ptr创建了一个智能指针smartPtr来管理动态分配的整数对象。然后,通过调用get()函数,我们获取了指向这个对象的原始指针rawPtr。接下来,我们可以像使用普通的C指针一样对其进行操作。 需要注意的是,一旦智能指针管理的对象不再需要,智能指针将自动释放内存。因此...
1、使用智能指针托管的对象,尽量不要在再使用原生指针 很多开发同学(包括我在内)在最开始使用智能指针的时候,对同一个对象会混用智能指针和原生指针,导致程序异常。 2、不要把一个原生指针交给多个智能指针管理 如果将一个原生指针交个多个智能指针,这些智能指针释放对象时会产生对象的多次销毁 3、尽量不要使用 get...
1,unique_ptr的数组智能指针,没有*和->操作,但支持下标操作[] 2,shared_ptr的数组智能指针,有*和->操作,但不支持下标操作[],只能通过get()去访问数组的元素。 3,shared_ptr的数组智能指针,必须要自定义deleter 小例子 #include<iostream>#include<memory>#include<vector>using namespacestd;classtest{public:...
智能指针类型定义了一个名为get的函数,它返回一个内置指针,指向智能指针管理的对象。此函数是为了这样一种情况而设计的:我们需要向不能使用智能指针的代码传递一个内置指针。使用get返回的指针的代码不能delete此指针。虽然编译器不会给出错误信息,但将另一个智能指针也绑定到get返回的指针上是错误的: shared ptr<i...
· 通过shared_from_this()返回this指针,不要把this指针作为shared_ptr返回出来,因为this指针本质就是裸指针,通过this返回可能 会导致重复析构,不能把this指针交给智能指针管理。 class A {shared_ptr<A> GetSelf() {return shared_from_this();// return shared_ptr<A>(this); 错误,会导致double free}};...
如上面的代码:智能指针可以像类的原始指针一样访问类的public成员,成员函数get()返回一个原始的指针,成员函数reset()重新绑定指向的对象,而原来的对象则会被释放。注意我们访问auto_ptr的成员函数时用的是“.”,访问指向对象的成员时用的是“->”。我们也可用声明一个空智能指针auto_ptr<Test>ptest(); ...
理解智能指针需要从下面三个层次: 从较浅的层面看,智能指针是利用了一种叫做RAII(资源获取即初始化)的技术对普通的指针进行封装,这使得智能指针实质是一个对象,行为表现的却像一个指针。 智能指针的作用是防止忘记调用delete释放内存和程序异常的进入catch块忘记释放内存。另外指针的释放时机也是非常有考究的,多次释放...
get(); cout<<*p2<<endl; } 通过智能指针的.get()方法可以获得其原始指针,赋值回普通的指针类型。 当然也有一些问题要注意: void f3() { int *p0 = new int(1); shared_ptr<int> p1(p0); shared_ptr<int> p2(p0);//不行,因为两个智能指针都会进行析构操作,对同一个指针删除两次会出问题 ...
在日常开发过程中,大多数朋友或许能熟练使用智能指针,但可能很少能停下脚步,去深度探索它们的内部实现,去精深我们的技艺。 这篇文章分为两个部分,逐一探索shared_ptr、weak_ptr和unique_ptr底层原理。 shared_ptr 与 weak_ptr shared_ptr用于「共享对象所有权」。它使用引用计数实现对象的共享与释放,进而达到控制对象...
一、什么是智能指针 在C++中没有垃圾回收机制,必须自己释放分配的内存,否则就会造成内存泄露。解决这个问题最有效的方法是使用智能指针(smart pointer)。智能指针是存储指向动态分配(堆)对象指针的类,用于生存期的控制,能够确保在离开指针所在作用域时,自动地销毁动态分配的对象,防止内存泄露。随着C++的发展,有三个解决...