void GetMemory(char *p){ p=(char *)malloc(100); } //这是正确的内存分配函数,使用的是双重指针,传递进来的是str的指针地址,*p就是原来的str void GetMemory2(char **p) { *p=(char*)malloc(100); } //这是使用引用的内存分配函数 void GetMemory3(char* &p) { p=(char*)malloc(100); } void Test(void){ char *str=NULL; GetMemory(str); // 该函数做的工作是 p=str, p=malloc(100); 和str一点关系都没有,str=NULL; //GetMemory2(&str); //该函数做的工作是 char**p=&str, str=*p=malloc(100),内存分配成功 //GetMemory3(str); // 传递的是str的引用,函数内的 p还是str,分配成功 strcpy(str, "Hello World!"); //现在可以 知道,第一个函数分配内存错误,strcpy也会失败 printf("%s\n", str); //输出只能是空
_____________________________________________________________________________________________________内存操作代码:
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;
}
这段代码显示的是不确定的内容,因为在函数调用结束时,p会被销毁,所以在常量区里的"hello world"内容会被销毁,返回p的地址后,现实的是不确定的内容。
void main()
{
char *str=NULL;
str=GetMemeory();
printf(str);
}