欢迎来到天天文库
浏览记录
ID:53660162
大小:67.00 KB
页数:2页
时间:2020-04-05
《浅析cc 中指针参数内存的传递.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、在C++中,函数的参数类型为结构体或类时,多数都是用指针和引甩如果函数的参数是一个指针,不要指望用该指针去申请动态内存。示例1中,Test函数的语句GetMemory(str,200)并没有使str获得期望的内存,str依旧是NULL,为什么?请看下文。voidGetMemory(char*p,intnum){p=(char*)malloc(sizeof(char)*num);}voidTest(void){char*str=NULL;GetMemory(str,100);//str仍然为NULLstrcpy(str,“hello”);//运行错误}示例1试图用指针参数申请动态内存
2、问题出在函数GetMemory中。编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是_p,编译器使_p=po如果函数体内的程序修改了_p的内容,就导致参数P的内容作相应的修改。这就是指针可以用作输出参数的原因。在本例中,」申请了新的内存,只是把_p所指的内存地址改变了,但是p丝毫未变。所以函数GetMemory并不能输出但可东西。事实上,每执行一次GetMemory就会泄露一块内存z因为没有用free释放内存。如果非得要用指针参数去申请内存,那么应该改用“指向指针的指针",见示例2。voidGetMemory2(char**p,intnum){*p=(char*)mall
3、oc(sizeof(char)*num);}voidTest2(void){char*str=NULL;GetMemory2(&str,100);//注意参数是&str,而不是strstrcpy(str,"hello");cout<4、)char*str=NULL;str=GetMemory3(100);strcpy(str,"hello");coutvvstr<5、;//str的内容是垃圾cout<6、是函数GetString2的设计概念却是错误的。因为GetString2内的"helloworld"是常量字符串,位于静态存储区,它在程序生命期内恒定不变。无论什么时候调用GetString2,它返回的始终是同一个"只读"的内存块。6+中,指针使用依旧很广泛,灵活性极大就注定了其危险程度会很高,所以在使用时一定要先明其理,再用之。
4、)char*str=NULL;str=GetMemory3(100);strcpy(str,"hello");coutvvstr<5、;//str的内容是垃圾cout<6、是函数GetString2的设计概念却是错误的。因为GetString2内的"helloworld"是常量字符串,位于静态存储区,它在程序生命期内恒定不变。无论什么时候调用GetString2,它返回的始终是同一个"只读"的内存块。6+中,指针使用依旧很广泛,灵活性极大就注定了其危险程度会很高,所以在使用时一定要先明其理,再用之。
5、;//str的内容是垃圾cout<6、是函数GetString2的设计概念却是错误的。因为GetString2内的"helloworld"是常量字符串,位于静态存储区,它在程序生命期内恒定不变。无论什么时候调用GetString2,它返回的始终是同一个"只读"的内存块。6+中,指针使用依旧很广泛,灵活性极大就注定了其危险程度会很高,所以在使用时一定要先明其理,再用之。
6、是函数GetString2的设计概念却是错误的。因为GetString2内的"helloworld"是常量字符串,位于静态存储区,它在程序生命期内恒定不变。无论什么时候调用GetString2,它返回的始终是同一个"只读"的内存块。6+中,指针使用依旧很广泛,灵活性极大就注定了其危险程度会很高,所以在使用时一定要先明其理,再用之。
此文档下载收益归作者所有