分析下列程序,输出结果:不确定,未定义行为。

#include<iostream>
#include<stdlib.h>
#include<string.h>
using namespace std;
void test(void) {
	char *str=(char *)malloc(100);
	strcpy(str,"hello");
	free(str);
	if(str!=NULL) {
		strcpy(str,"world");
	}
	printf(str);
}

int main()
{
	test();
	return 0;
}

      指针释放存储空间后没有置为NULL,变成野指针。

分析:野指针,不能通过简单的NULL进行判断,delete或free只是释放了指针所指向的内存区域,并没有干掉指针本身,所以指针指向的是“垃圾”指针,所以free或者delete之后要把指针置为NULL。

    free(str)只是释放了str指针所指向的内存区域,并未修改指针本身的地址值,所以str!=NULL,但是str是一个野指针(野指针 指向一个已删除的对象或未申请访问受限内存区域的指针),访问内存区域是受限的。不过,本人在mac和linux平台上运行上述代码,虽然有警告,但是最终都输出了world。

 

  

    释放以后按照理论是不能访问的,如果这个时候访问并且往里面输入数据的话系统不能保证数据安全,会有可能会出现world 但不代表一直会出现world。

 

posted on 2017-08-01 21:33  王小东大将军  阅读(169)  评论(0编辑  收藏  举报