C/C++ 指针删除的几个细节
2016-11-11 11:25
302 查看
在C/C++中,当指针需要删除时,对于new的指针,调用delete就可以删除 比如 :
int* p = new int(17);
delete p;
有时候为了避免使用错误,一般在delete之后,将p置为NULL,即:
int* p = new int(17);
delete p;
p = NULL;
有时候为了方便及统一处理指针的申请及释放,一般放到将删除操作放到一个方法中去做,即:
int* p = new int(17);
void deleteP(int* a){
delete a;
a = NULL;
}
但是这样对a赋值为NULL,对于调用的指针p来说,虽然p占用的内存被释放了,但是p这个指针还是指向delete之前的地址,即p != NULL ,所以某些通过根据 p是否为NULL进行判断而执行的操作就不对了,比如 :
if ( p != NULL)
{
.....
}
上面的做法就不对了
有一个方法可以解决,就是指针释放的时候,传递进去的不是指针,而是指针的引用,即 :
int* p = new int(17);
void deleteP(int*& a){
delete a;
a = NULL;
}
这样调用p就变为NULL了,上面的根据p是否为NULL进行的判断也就正确了
有时候这种操作也可以通过一个宏定义去完成,即 :
#define CC_SAFE_DELETE(p) if(p) { delete (p); (p) = NULL; }
因为宏定义执行的时候,是到调用处进行展开,并不像方法那样做,所以通过宏定义进行删除后,调用指针p也就变成NULL了。
int* p = new int(17);
delete p;
有时候为了避免使用错误,一般在delete之后,将p置为NULL,即:
int* p = new int(17);
delete p;
p = NULL;
有时候为了方便及统一处理指针的申请及释放,一般放到将删除操作放到一个方法中去做,即:
int* p = new int(17);
void deleteP(int* a){
delete a;
a = NULL;
}
但是这样对a赋值为NULL,对于调用的指针p来说,虽然p占用的内存被释放了,但是p这个指针还是指向delete之前的地址,即p != NULL ,所以某些通过根据 p是否为NULL进行判断而执行的操作就不对了,比如 :
if ( p != NULL)
{
.....
}
上面的做法就不对了
有一个方法可以解决,就是指针释放的时候,传递进去的不是指针,而是指针的引用,即 :
int* p = new int(17);
void deleteP(int*& a){
delete a;
a = NULL;
}
这样调用p就变为NULL了,上面的根据p是否为NULL进行的判断也就正确了
有时候这种操作也可以通过一个宏定义去完成,即 :
#define CC_SAFE_DELETE(p) if(p) { delete (p); (p) = NULL; }
因为宏定义执行的时候,是到调用处进行展开,并不像方法那样做,所以通过宏定义进行删除后,调用指针p也就变成NULL了。
相关文章推荐
- C/C++ 指针删除的几个细节
- 【语法】C++拷贝构造函数的几个细节
- 21天学通c++之第二周 指针 8.5 在自由存储区中创建和删除对象 高手进来看看我的评论对不
- 关于C++中char型数组、指针及strcpy函数的细节观察
- C++第17周项目2——用指针玩字符串(2)删除字符
- c++ 指针的几个测试例子
- 常用的几个指针删除器
- C++语法基础--类(class)--类型别名,this指针,初始化式,友元的一些注意细节
- C++:删除map元素,当value值为指针时,如何释放内存。
- C++中拷贝构造函数的几个细节问题
- C++拷贝构造函数几个细节
- C++拷贝构造函数的几个细节
- 关注C++细节——浅谈指针使用中注意事项
- C++拷贝构造函数的几个细节
- c++几个大牛博客。不能迷失于细节!
- C++拷贝构造函数的几个细节
- C++拷贝构造函数的几个细节
- C++ 使用delete删除指针后应该做的工作
- C/C++细节(指针相关)
- C++ 使用delete删除指针