天天看点

auto_ptr

1、

  int *pi = new int(1024);

  delete pi; // 释放pi指向的int对象占用的内存空间

  pi = 0; // 将pi设置为0,不指向任何东西,为null

  注意:删除0值的指针是安全的,但是没有任何意义。对于上面的情况,先释放内存,再置为null。顺序不能颠倒,如果颠倒了,会导致内存泄漏。

2、在stack上分配的内存,用完后,系统会自动释放,调用析构方法。在heap上,通过new分配内存,必须使用delete,手动释放内存,如果忘记,会导致内存泄漏。如果重复释放内存,会破坏自由存储区,导致分配在上面的其他对象受到破坏。(stack记录程序的执行过程,heap存放数据)

3、为了解决上面的问题,使用auto_ptr

4、auto_ptr是一个模版类,对一个类型的指针进行封装,把delete操作放在析构方法中,由于析构方法总是被调用,就保证了内存不会泄露。

5、auto_ptr是一个模版类,为了让auto_ptr使用起来像一个指针,重载*与->操作符。

6、用a对象copy构造b对象的时候,要把a的指针设为0,为什么?

  如果,不把a的指针设为0,a,b都会在析构方法中进行delete,导致重复释放。

7、把a对象copy赋值给b对象的时候,首先要把b对象的指针delete,然后把a的指针设为0,为什么?

  b的指针指向了a的指针,要对b原来的指针释放掉,不然内存泄漏。

8、copy构造是破坏性操作,lhs的指针指向rhs的资源,rhs的指针设为null。为了避免重复释放。

9、copy赋值是破坏性操作,首先对lhs进行delete,避免内存泄漏。其次,lhs的指针指向rhs的资源,rhs的指针设为null。为了避免重复释放。