关于野指针及指针所指内存被回收后的一些误区

我们是不是经常会有这样的疑问: 内存空间被回收是不是这块内存空间被清空了?何为野指针 ,怎样避免野指针?

    //在堆内存申请一块内存 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编辑  收藏  举报

导航