void GetMemory(char *p)
{
p = (char *)malloc(100);
}
void Test(void)
{
char *str = NULL;
GetMemory(str);
strcpy(str, “hello world”);
printf(str);
}
請問運行Test 函數(shù)會有什么樣的結果?
答:程序崩潰。
因為GetMemory 并不能傳遞動態(tài)內存,Test 函數(shù)中的 str 一直都是 NULL。
strcpy(str, “hello world”);將使程序崩潰。
char *GetMemory(void)
{
char p[] = “hello world”;
return p;
}
void Test(void)
{
char *str = NULL;
str = GetMemory();
printf(str);
}
請問運行Test 函數(shù)會有什么樣的結果?
答:可能是亂碼。
因為GetMemory 返回的是指向“棧內存”的指針,該指針的地址不是 NULL,但其原現(xiàn)的內容已經(jīng)被清除,新內容不可知。
void GetMemory2(char **p, int num)
{
*p = (char *)malloc(num);
}
void Test(void)
{
char *str = NULL;
GetMemory(&str, 100);
strcpy(str, “hello”);
printf(str);
}
請問運行Test 函數(shù)會有什么樣的結果?
答:(1)能夠輸出hello;(2)內存泄漏
void Test(void)
{
char *str = (char *) malloc(100);
strcpy(str, “hello”);
free(str);
if(str != NULL)
{
strcpy(str, “world”);
printf(str);
}
}
請問運行Test 函數(shù)會有什么樣的結果?
答:篡改動態(tài)內存區(qū)的內容,后果難以預料,非常危險。
因為free(str);之后,str 成為野指針,if(str != NULL)語句不起作用。