- C++没有明确定义如何释放指向不是new分配的内存地址的指针。(p152,118)
以下几种情况都可能引发运行时或编译时错误:
1)delete不是new分配的空间
2)重复delete new分配的空间两次以上
3)在释放动态数组时忘了方括号对
int i;
int
*pi=&i;
delete
pi;
//vs 2008
会运行时错误
string str=
"dwarves"
;
delete
str;
//vs 2008
会编译错误
int
*p=
new
int
();
delete
p;
delete
p;
//vs 2008
会运行时错误
int
*p=
new
int
[10]();
delete
p;
//vs 2008
运行时并未报错,但会产生内存泄露。对于某些系统或元素类型,有可能带来严重的运行时错误
//
因此在释放动态数组时千万别忘了方括号对
如果指针值为0,则在其上delete操作是合法的,C++保证删除0的指针是安全的。但这样做无任何意义
int *p=0;
delete p;
//ok
笔记:由此可以看出类的设计者,只需管理自己的指针数据成员的析构,而不能去管理类的使用者传进来的指针参数。如果也去析构,很有可能析构传进的参数时发生crash。
记住谁分配谁释放的原则
- 对于内置类型或没有定义默认构造函数的类型,采用不同初始化方式有着显著的差别(p151):
int *p=new int; //不加圆括号,内置类型不会初始化
int *pi=new int(); //初始化为0
对于有默认构造函数的类类型则以下两句效果一样
string *ps=new string;
string *ps=new string();
new表达式无法获取需要的内存空间,系统将抛出bad_alloc的异常