指针做函数形参分析

    有一个经典的C语言函数题目:

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

void Test( void )
{
 char *str = NULL;
 GetMemory( str );
 strcpy( str, "hello world" );
 printf( str );
}


   经过指针变量通过函数Getmemory后,还是null,并没有分配内存,所以编译运行会出错,或者直接编译报错。

   原因在于,函数参数传递的时候,直接传递是值传递,需要引用传递需要加上‘&’,作为值传递,p=str,也就是说,p指向的地址和str指向的地址是相同的,同为指向null,但是在函数中局部变量p又重新分配了100个字节的变量,他的值发生变化,指向了别的地址,但是str并没有变化,所以函数对str是无效的。

  究其根本原因,在于p指针的地址和str指针的地址不一样,两者只是共同指向同一个地方(p先指向str指向的地方,后又指向一块内存,然后在函数结束后内存收回)。

   一般用指针做函数形参是为了传入参数地址,来进行修改实参数的值,即指针指向的值,但是如果要用来修改指针本身的值则需要指针的指针或者指针变量的传址引用。

一般指针做形参的用法:

  

swap( int* p1,int* p2 )
{
 int p;
 p = *p1;
 *p1 = *p2;
 *p2 = p;
}

最开始的程序的修改版应该为:

void GetMemory2(char **p, int num) 
{ 
*p = (char *)malloc(sizeof(char) * num); 
if ( *p == NULL )
{
 ...//进行申请内存失败处理
} 
} 
void Test(void)
{ 
  char *str=NULL; 
  GetMemory=(&str); 
  strcpy(str,"hello world"); 
  printf(str); 
  free( str ); 
}

修改版本2:

char *GetMemory()
{ 
  char *p=(char *)malloc(100); 
if ( *p == NULL )
   {
     ...//进行申请内存失败处理
   }
  return p; 
} 
void Test(void){ 
  char *str=NULL; 
  str=GetMemory();
  strcpy(str,"hello world"); 
  printf(str); 
  free( str ); 
}

版本2使用一个指针函数,返回一个指向分配好内存的地址,返回的是一个值(p指向的地址,一个int变量(处理器位数决定)),是能够返回的,如果返回的是指向局部变量的指针,那么会发生程序错误。指针做函数返回值,指向的值在函数结束后不能够被注销,否则发生程序错误(返回时并没有错,使用的时候已经变成未知的值,可能造成系统紊乱)。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值