TEST1
void GetMemory1(char *p)
{
p = (char *)malloc(100);
}
void Test1(void)
{
char *str = NULL;
GetMemory1(str);
strcpy(str, "hello world");
printf(str);
}
- 调用GetMemory( str )后,str并未产生变化,依然是NULL。改变的只是str的一个拷贝的内存的变化 。
- strcpy( str, "hello world" );程序运行到这将产生错误。
TEST2
char *GetMemory( void )
{
char p[] = "hello world";
return p;
}
void Test( void )
{
char *str = NULL;
str = GetMemory();
printf( str );
}
- GetMemory中的p[]为函数内的局部自动变量,在函数返回后,内存已经被释放。根源在于不理解变量的生存期。用调试器逐步跟踪Test,发现执行str=GetMemory语句后str不再是NULL指针,但是str的内容不是“hello world”,而是垃圾.
TEST3
void GetMemory( char **p, int num )
{
*p = (char *) malloc( num );
}
void Test( void )
{
char *str = NULL;
GetMemory( &str, 100 );
strcpy( str, "hello" );
printf( str );
}
- 运行正确,传入GetMemory的参数为字符串指针的指针,但有内存泄露。
TEST4
void Test( void )
{
char *str = (char *) malloc( 100 );
strcpy( str, "hello" );
free( str );
... //省略的其它语句
}
运行正确,但有内存泄露。与TEST3存在同样的问题,在执行malloc后未进行内存是否申请成功的判断。此外,在free(str)后未置str为空,导致可能变成一个“野指针”,应加上 str=NULL。
TEST5
char* GetMemory(int num)
{
char* p = (char*)malloc(100);
return p;
}
void Test(void)
{
char* str = NULL;
str = GetMemory(100);
strcpy(str, "hello");
cout<<str<<endl;
}
- 运行正确。注意TEST5和TEST2的区别。虽然都是局部变量,但TEST5用函数返回值来传递动态内存;而TEST2return语句返回指向“栈”内存的指针,因为该内存在函数结束时自动消亡。