欢迎来到天天文库
浏览记录
ID:14643990
大小:19.80 KB
页数:5页
时间:2018-07-29
《函数参数的传递问题(指针的指针)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、函数参数的传递问题(指针的指针)(转)函数参数的传递问题(指针的指针)(转)程序1:voidmyMalloc(char*s)//我想在函数中分配内存,再返回{ s=(char*)malloc(100);}voidmain(){ char*p=NULL; myMalloc(p);//这里的p实际还是NULL,p的值没有改变,为什么? if(p)free(p);}程序2:voidmyMalloc(char**s){ *s=(char*)malloc(100);}voidmain(){ char*p=NULL; myMalloc(&p);//这里的p可以得到正确的值了 if(p)f
2、ree(p);}程序3:#includevoidfun(int*p){ intb=100; p=&b;}main(){ inta=10; int*q; q=&a; printf("%d",*q); fun(q); printf("%d",*q); return0;}结果为1010程序4:#includevoidfun(int*p){ *p=100;}main(){ inta=10; int*q; q=&a; printf("%d",*q); fun(q); printf("%d",*q); return0;}结果为10100
3、为什么?---------------------------------------------------------------1.被分配内存的是行参s,p没有分配内存2.被分配内存的是行参s指向的指针p,所以分配了内存---------------------------------------------------------------不是指针没明白,是函数调用的问题!看看这段:7-4-1指针参数是如何传递内存的? 如果函数的参数是一个指针,不要指望用该指针去申请动态内存。示例7-4-1中,Test函数的语句GetMemory(str,200)并没有使s
4、tr获得期望的内存,str依旧是NULL,为什么?voidGetMemory(char*p,intnum){ p=(char*)malloc(sizeof(char)*num);}voidTest(void){ char*str=NULL; GetMemory(str,100); //str 仍然为 NULL strcpy(str,"hello"); // 运行错误}示例7-4-1 试图用指针参数申请动态内存毛病出在函数GetMemory中。编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是 _p,编译器使 _p=p
5、。如果函数体内的程序修改了_p的内容,就导致参数p的内容作相应的修改。这就是指针可以用作输出参数的原因。在本例中,_p申请了新的内存,只是把_p所指的内存地址改变了,但是p丝毫未变。所以函数GetMemory并不能输出任何东西。事实上,每执行一次GetMemory就会泄露一块内存,因为没有用free释放内存。如果非得要用指针参数去申请内存,那么应该改用“指向指针的指针”,见示例7-4-2。voidGetMemory2(char**p,intnum){ *p=(char*)malloc(sizeof(char)*num);}voidTest2(void){ char
6、*str=NULL; GetMemory2(&str,100); // 注意参数是 &str,而不是str strcpy(str,"hello"); cout<7、Test3(void){ char*str=NULL; str=GetMemory3(100); strcpy(str,"hello"); cout<
7、Test3(void){ char*str=NULL; str=GetMemory3(100); strcpy(str,"hello"); cout<
此文档下载收益归作者所有