几个关于GetMemory的经典问题

 TEST1

void GetMemory1(char *p)
{
    p = (char *)malloc(100);
}

void Test1(void) 
{
    char *str = NULL;
    GetMemory1(str); 
    strcpy(str, "hello world");
    printf(str);
}
  1. 调用GetMemory( str )后,str并未产生变化,依然是NULL。改变的只是str的一个拷贝的内存的变化 。   
  2. 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语句返回指向“栈”内存的指针,因为该内存在函数结束时自动消亡。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值