现有如下内存操作代码:
void GetMemeory(char *p)
{
p=(char*)malloc(100);
}
void main()
{
char *str=NULL;
GetMemory(str);
strcpy(str,"hello world");
printf(str);
}
以上这段代码运行会直接崩溃,虽然在函数内部分配了内存空间并把地址赋予指针p,但是函数调用结束时,系统会自动销毁形参指针*p,所以函数调用后并没有返回分配好的内存地址给指针str,str是没有内存空间的,调用strcpy函数往一个空的内存空间写内容,会导致程序崩溃,而且函数内申请的堆空间没有手动释放,容易造成内存泄露。
稍作改进的内存操作代码:
void GetMemeory(char **p)
{
*p=(char*)malloc(100);
}
void main()
{
char *str=NULL;
GetMemory(&str);
strcpy(str,"hello world");
printf(str);
}
在这段代码中,获得内存的是*p指向的变量,即str获得了内存,p会在函数结束后销毁,所以不会改变&str的值,所以不影响使用,但是使用后没有对申请的内存做任何处理,因此可能导致内存泄露。
关于void* GetMemory()的讨论,有如下代码:
char* GetMemeory()
{
char p[]="hello world";
return p;
}
void main()
{
char *str=NULL;
str=GetMemeory();
printf(str);
}
这段代码显示的是不确定的内容,因为在函数调用结束时,p会被销毁,所以在常量区里的"hello world"内容会被销毁,返回p的地址后,现实的是不确定的内容。