getMeory(*p)指针

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);
}

猜你喜欢

转载自blog.csdn.net/yizimu/article/details/81112563
今日推荐