Chinaunix首页 | 论坛 | 博客
  • 博客访问: 65828
  • 博文数量: 42
  • 博客积分: 1730
  • 博客等级: 上尉
  • 技术积分: 430
  • 用 户 组: 普通用户
  • 注册时间: 2009-08-02 13:06
文章分类

全部博文(42)

文章存档

2011年(1)

2009年(41)

我的朋友

分类: C/C++

2009-11-23 18:02:46

以前在学习的时候,知道delete释放指针所指向的内存,总以为在释放指针后,该指针的值会发生改变
今天在学校到类的拷贝构造函数的时候,单步调试发现delete释放内存,但指针所指向的地址值不发生改变
假设有个指针变量a,delete之前它指向地址0x123456
delete之后a所指向的仍然是0x123456,但是0x123456该内存的已经不属于该进程,内容可能被其他进程改变,
也可能还没有被其他进程利用,如果delete一次之后,再重复delete将发生错误,因为该内存已不属于它了
所以良好的编程风格是在delete之后,要将指针变量赋值为null
具体参见下面程序(这里只是用简单变量演示,没有用类):
// delete.cpp : Defines the entry point for the console application.
#include "stdafx.h"
int _tmain(int argc, _TCHAR* argv[])
{

 int* da = new int(5);
 printf("%x\n", da);
 printf("%d\n", *da);
 delete da;//da=NULL;
 printf("%x\n", da);
 printf("%d\n", *da);
 
 return 0;
}
/*
393928
5
393928
-572662307
请按任意键继续. . .
*/
阅读(346) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~