文章目录
一、
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;
}
这个代码的运行结果是什么呢?
我们来分析一下:
发生了这样的错误是因为什么呢?
-
这里在strcpy中相当于对NULL空指针进行了解引用,程序会崩溃,然后代码最后没有释放空间,也会造成内存的泄露。
二、
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变量是在栈区创建的,而出了函数范围就会被销毁了,所以p的地址并没有传给str,此时的str就属于野指针了,非法访问,也能看到编译器的报错提醒我们返回了局部变量P的地址。
三、
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;
}
这里确实能打印出
但是有一个问题就是没有释放malloc开辟的空间
注意:这里开辟空间的时候要用二级指针,解引用指向str然后才能开辟成功
四、
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;
}
这段代码又有什么问题呢?
可以看到在这里我们先释放了str,所以开辟的空间被释放掉,我们不能找到它了,并且在这里释放后应该主动将str=NULL以免进入if中,虽然这里运行有些编译器确实能打印出world,但是这种写法本身就是错误的