内存操作的考察点:①指针 ②变量生存期及作用范围 ③动态内存申请和释放

笔试题******************************************************************************

//meitu笔试 内存管理
void getMemory(char *p){
	p = new char[100];
}
void test(){ char *str=NULL; getMemory(str);//每执行一次getMemory就会申请一块内存,却不能释放 strcpy(str,"hello meitu!"); //这一步编译出错 cout << str <<endl; }

 

F5调试到strcpy(str,"hello meitu!");这里会出错,因为传递实参到函数时,指针p会生成副本_p,动态分配的内存空间,只是改变了_p,没有改变p,因此调用完getMemory函数后,test()中str指针依然为NULL空,strcpy参数指针为空就会出错(至于为什么出错,还不知道啊,打个?)

毛病出在函数GetMemory 中。编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是 _p,编译器使 _p = p。如果函数体内的程序修改了_p的内容,就导致参数p的内容作相应的修改。这就是指针可以用作输出参数的原因。在本例中,_p申请了新的内存,只是把 _p所指的内存地址改变了,但是p丝毫未变。所以函数GetMemory并不能输出任何东西。事实上,每执行一次GetMemory就会泄露一块内存,因为没有用free释放内存。

改正:用二级指针,对指针本身进行的操作,而不是指针指向的空间

 

void getMemory(char **p){//二级指针
	//C++中写 p = new char *[100];运行是错误的,正确的该怎样写???
	*p=(char*)malloc(sizeof(char)*100);
}
void test(){
	char *str=NULL;
	getMemory(&str);//传引用,又可理解为对指针取地址
	strcpy(str,"hello meitu!");
	cout << str <<endl;//这样居然能输出字符串,*str只能输出一个h
}

  

(未完待续 继续总结。。。)

参考:C/C++ 笔试面试(3)——内存管理GetMemory  

程序员面试宝典 P68

posted on 2014-05-21 09:48  zhangxh_Doris  阅读(653)  评论(0编辑  收藏  举报