C++之delete常见错误总结

1、动态分配内存后释放了一次,再次释放
1)直接删除2次

int main()  
{  
   int *a = new int(50);  
   cout<<*a<<endl;  
   delete a;  
   delete a;  
   return 0;  
}  

2)另外一个指针指向分配的内存,然后把这个2个指针都删除

int* p1 = new int(50);  
int* p2 = p1; //p2和p1 现在指向同一内存地址  
cout << *p1 << endl;  
cout << *p2 << endl;  
delete p1; //OK  
delete p2; //ERROR! p2所指的内存,已通过delete p1而被释放,不可再delete一次  

2、删除是一个普通指针或者不是一个指针
1)删除的是一个普通指针

nt  a = 50;  
int *p = &a;  
delete p  

2) 删除的不是一个指针

string ss = "chenyu";  
delete ss;  

3、删除了由系统释放的指针

int* p = new int[50];   
int chenyu[50];    
p = chenyu;    
delete [] p;  

我们是想把要释放p最初通过new int[50]而得到的内存空间,但事实上,p那时已经指向chenyu[100]了。结果,第一、最初的空间并没有被释放。第二、girl[100] 本由系统自行释放,现在我们却要强行释放它。

4、删除动态分配的指针的时候没有指向最初的地址

int *p = new int[3];  
*p = 1;  
cout<<*p<<endl;  
*p++ = 2;  
cout<<*p<<endl;  
delete[] p;  

当一个指针通过 +,-等操作而改变了指向;那么在释放之前,应确保其回到原来的指向。如下所示:在 delete [] p 时,p指向的是第二个元素,结果该释放将产生错位:第一个元素没有被释放,而在最后多删除了一个元素
正确代码如下:

int *p = new int[3];  
*p = 1;  
cout<<*p<<endl;  
*p++ = 2;  
p--;  
cout<<*p<<endl;  
delete[] p;  

读者可以亲自测试错误,然后再去修正,这里就没有贴错误的效果是什么

猜你喜欢

转载自blog.csdn.net/u012692537/article/details/80796468
今日推荐