1、成对使用new,delete要采用相同的形式
new,delete都是在堆中动态分配内存内存要用的,需要自己收回资源。
new会产生两个动作:1、分配内存,2. 调用构造函数。delete也是两个动作,1、调用析构函数,2. 释放内存。
那么,当我们分配数组对象时,如何知道调用多少次构造和析构函数呢?
编译器内部会额外分配空间存储对象的数量,当对数组对象调用构造和析构函数时就可以根据这个数量值来进行循环处理了。
那么,delete时需要判断是否是数组对象,数组对象的话必须使用[],这样delete就知道释放的是一个数组。
比如:
string *ptr1=new string[100];
delete [] ptr1;
2、以独立语句将newed对象置入智能指针
之前说过将对象置入智能指针是用来防止资源泄露。那么,独立语句是啥意思呢?我们看下面这两个例子:
一种是:f(shared_ptr(new widget),priority());
另一种是:
shared_ptrpw (new widget);
f(pw,priority());
上面的内容看起来没有问题,但是我们看第一种参数执行顺序(编译器可以自由排列参数执行顺序)
1.执行new widget 2 调用priority() 3.调用shared_ptr的构造函数。
那么,如果在调用priority函数时出现问题,就会产生资源泄露。
所以,最好的办法就是第二种,保证资源可以被放进智能指针内们就可以防止资源泄露。