第一题
试题如下:
void GetMemory(char* p) { p = (char*)malloc(100); } void Test(void) { char* str = NULL; GetMemory(str); strcpy(str, "hello world"); printf(str); } int main() { Test(); return 0; }
运行结果如下:
通过上述我们可以发现程序已经崩了。
解答:
上述代码主要存在以下错误。
- 这里传入的是一级指针,没有对str中存放的地址NULL进行改变,所以后面执行strcmp的内容会让程序崩溃。
动态申请内存有可能失败,所以应该增加判断。- 动态创建的内存没释放。
改正方法:
方法一:如果需要改变str,改变变量用一级指针,改变指针用二级指针,所以我们可以使用二级指针对其进行操作,如下:
void GetMemory(char** p) { *p = (char*)malloc(100); if (NULL == p) return 1; } void Test(void) { char* str = NULL; GetMemory(&str); strcpy(str, "hello world"); printf(str); //释放 free(str); str = NULL; } int main() { Test(); return 0; }
方法二:还有一种方法是,将动态申请的内存以返回值的形式传出。
char* GetMemory(char* p) { p = (char*)malloc(100); return p; } void Test(void) { char* str = NULL; str = GetMemory(str); strcpy(str, "hello world"); printf(str); free(str); str = NULL; } int main() { Test(); return 0; }
第二题
试题如下:
char* GetMemory(void) { char p[] = "hello world"; return p; } void Test(void) { char* str = NULL; str = GetMemory(); printf(str); } int main() { Test(); return 0; }
运行结果如下:
通过结果不难发现程序运行错误。
解答:
这是返回栈空间地址问题,p的生命周期在GetMemory函数执行完了就被销毁了,str指向的是个野指针, GetMemory 并不能传递动态内存,Test 函数中的str 一直都是 NULL。strcpy(str, “hello world”);将使程序崩溃。
当然没有内存释放也是它存在的一个问题
第三题
试题如下:
void GetMemory(char** p, int num) { *p = (char*)malloc(num); } void Test(void) { char* str = NULL; GetMemory(&str, 100); strcpy(str, "hello"); printf(str); } int main() { Test(); return 0; }
运行结果如下
上述我们可以发现是正常,那么真的是这样吗?
解答:
其实这题存在一个很简单的申请未释放的问题,导致内存泄漏。
改正:
void GetMemory(char** p, int num) { *p = (char*)malloc(num); } void Test(void) { char* str = NULL; GetMemory(&str, 100); strcpy(str, "hello"); printf(str); free(str); str = NULL; } int main() { Test(); return 0; }
第四套
试题如下:
void Test(void) { char* str = (char*)malloc(100); strcpy(str, "hello"); free(str); if (str != NULL) { strcpy(str, "world"); printf(str); } } int main() { Test(); return 0; }
运行结果如下:
我们发现这跟第三题一样,并没有出现报错,那么它是正确的吗?答案当然是否定的。
解答:
执行 char *str = (char *) malloc(100); 后未进行内存是否申请成功的判断;
另外,在free(str)后未置str为空,导致可能变成一个“野”指针,应加上: str = NULL;
改正:
void Test(void) { char* str = (char*)malloc(100); if (str == NULL) return; strcpy(str, "hello"); free(str); str = NULL; if (str != NULL) { strcpy(str, "world"); printf(str); } } int main() { Test(); return 0; }
以上就是关于动态内存管理的几个经典的试题,大家通过练习我相信对我们的知识点的掌握肯定更加牢固!