为什么delete指针后指针设为null

int *p;/*。。。。。。。。*/delete p;
p=null;

  看代码的过程中,有这么一个疑问。删除了指针p,指针p既是不存在,怎么还能设置指针p为null呢?为什么还要设置为null呢?

  后来得知计算机上删除数据的方式:删除数据(视频,音乐,文件等),计算机并不会把存储数据的硬盘区域(或者是内存)的内容擦除消去,而是将内容标记为可覆盖,这时候我们就不能再访问到数据,而这些可覆盖据数据会留在原来的硬盘区域直到被新的数据逐渐覆盖。(所以,删除了数据之后,只要没有对硬盘进行过多的操作,还是有可能复原数据的(所以,当我删除不可告人的东西时就要反复下载东西填充硬盘吗?(●ˇ?ˇ●)))

  正题来了,delete p 的含义不是删除消灭p。而是让p所指向的地址的内容标记为可覆盖。而p=null 则是将指针指向空。

  delete p 之后,p指向地址可覆盖,但是p仍然指向原来的地址,随着程序的运行,原本内存可能被使用,p指向可能内容改变。所以为了安全起见,将p指向null。避免p不小心再次被使用。

  如果直接p=null,而不先 delete p。那么p的地址不可被覆盖,造成内存泄漏(内存不可以再使用)。

这是我对这个问题的理解,如果有什么不对和补充,欢迎来信息。

时间: 2024-08-24 17:05:43

为什么delete指针后指针设为null的相关文章

delete指针以后应赋值为NULL

 delete p后,只是释放了指针指向的内存空间.p并不会自动被置为NULL,而且指针还在,同时还指向了之前的地址 delete NULL编译器不会报错(因为delete空指针是合法的) 例: 对一个非空指针delete后,若没有赋NULL,若再次delete的话,有可能出现问题. 如下代码 int *p = new int(3); delete p; delete p; 用VC编译运行将出现问题. 将其改为: int *p = new int(3); delete p; p = NULL

free 或delete后指针怎么样了

free()和delete()只是把指针所指向的内存释放掉,但是并没有把指针本身删除,也没有把指针置为NULL; #include<iostream> using namespace std; int main(void) { char *p=(char *)malloc(100*sizeof(int)); strcpy(p,"Hello World"); cout<<"释放前指针p的地址:"<<&p<<end

c++,new,delete,成员指针

new和delete用来申请动态内存空间,一定要配对使用 #include <string> #include <ctype.h> #include <vector> #include <iostream> #include <fstream> // using declarations states our intent to use these names from the namespace std using namespace std;

【转载】 free(p)后指针问题

转载自:http://blog.csdn.net/onestep365/article/details/1897626 #include <stdio.h>#include <string.h>#include <stdlib.h>int main(){  char *str = (char *)malloc(100);  strcpy(str, "hello");  free(str);  if(str != NULL)    {      str

C++ delete []p 数组指针,如何知道该数组大小的

本来只是一时兴起,想动手整整大学学的很渣的C++,可是一段小小的代码缺牵扯出一堆问题来,好有趣. 来看一段代码: void main() { char p[6]; char *buf = new char[4]; strcpy(buf,"012356789");//这里越界不会报错 strcpy(p,"Hello"); //若此处越界立即报错 cout<<p<<endl; cout<<buf<<endl; delete

测试对象销毁后指针是否还可以使用

<span style="font-size:18px;">// 04-测试对象销毁后指针是否还可以使用 // // Created by wanghy on 15/8/13. // // //为了直观,直接将.m和.h文件写在main.m中. #import <Foundation/Foundation.h> //定义 person类 包含 姓名,年龄和性别 @interface person : NSObject { @public NSString * _

c++中的悬浮指针和野指针 二级指针

(1) c++中的悬浮指针:声明了但没有被付值的指针,它指向内存中的任意一个空间.避免悬浮指针的一个方法是开始就付值为NULL (2)"野指针"不是NULL指针,是指向"垃圾"内存的指针.人们一般不会错用NULL指针,因为用if语句很容易判断.但是"野指针"是很危险的,if语句对它不起作用.野指针的成因主要有两种: 一.指针变量没有被初始化.任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气.所以,指针变量在创建的同

C++智能指针--auto_ptr指针

auto_ptr是C++标准库提供的类模板,头文件<memory>,auto_ptr对象通过初始化指向由new创建的动态内存,它是这块内存的拥有者,一块内存不能同时被分给两个拥有者.当auto_ptr对象生命周期结束时,其析构函数会将auto_ptr对象拥有的动态内存自动释放.即使发生异常,通过异常的栈展开过程也能将动态内存释放.auto_ptr不支持new数组. auto_ptr的出现,主要是为了解决"有异常抛出时发生内存泄漏"的问题.如下的简单代码是这类问题的一个简单示

二维数组做函数参数、指向指针的指针做函数参数

这里有一篇文章  写的很好http://blog.csdn.net/f81892461/article/details/8974087 该文章中有一句话  总之就是:数组无法作为参数,总会被编译器将地址赋值给形参指针的,即使指针定义成数组形式,也还是指针.然后各种差别都是由数组和指针不同的定位元素的方式导致的. 这句话说的很对啊,数组做形参的是时候都是被当成指针来处理的.不明白这句话的可以看一下,参考文章链接里的那幅图,注意比较一下下图中的两个:data+1,第一个data+1指向的是元素dat