关于野指针及指针所指内存被回收后的一些误区
我们是不是经常会有这样的疑问: 内存空间被回收是不是这块内存空间被清空了?何为野指针 ,怎样避免野指针?
//在堆内存申请一块内存 32位 4字节,64位 8字节 的空间 ,定义一个指针变量 p 指向这块空间
int * p = (int *)malloc(sizeof(int));
//给变量p所指的变量地址赋值
*p = 10;
// free(p)回收p所指的内存 注意 : 回收内存的空间,只是说这块空间可以再被利用了,并不是这块空间的数据被清空了,这块空间还储存的是10的变量。执行free(p)这一句代码后的p就是野指针;
free(p);
cout << "&p is ---- before"<< &p<<endl;
cout << "p is ---- before"<< p <<endl;
此时打印结果 :
&p is ---- before 0x7ffeefbff508
p is ---- before 0x102802d00
//此时的p指向的地址仍然是10所在的内存地址,但这块址已被回收了此时的p就是一个野指针 。 由此可见 野指针 :指向一个已被回收/释放的内存地址的指针
//为避免野指针,应该加上这一句
p = NULL ;
cout << "&p is ---- after "<< &p<<endl;
cout << "p is ---- after "<< p <<endl;
此时打印结果 :
&p is ---- after 0x7ffeefbff508
p is ---- after 0x0
些时p被赋为NULL,为一个空指针。
因为 p是定义的一个指针变量,是存在栈中的,函数没执行完 p的地址是不会被清空 &p的值才没有改变。
posted on 2018-12-03 15:12 justdoXiao 阅读(231) 评论(0) 编辑 收藏 举报