再说参数传递

大家好,我目前就职于一家工业制造公司,我的email是wuxfei@gmail.com,工作近3年时间了,今天借助于CSDN博客温习一下c++参数传递,如有错误还望读者指正!

我们先看一下面一段代码

void GetMemory(char *p, int num)
{
	p = (char *)malloc(sizeof(char) * num);
}

void main(void)
{
	char *str = NULL;
	GetMemory(str, 100);
    strcpy(str, "Hello");
}

在这段代码中,main函数希望通过调用GetMemory获得一片指定大小的内存区域,但是经过编译运行后发现,程序运行到strcpy(str, "Hello");时,程序挂掉了!

GetMemory中已经申请了内存空间,并且已经赋值给了指针变量呀,为什么str还是NULL呢?

先看看函数的执行过程:

1、main函数在执行语句GetMemory(str, 100);时,编译系统是将str的值赋值给p了,就是说在还未执行p = (char *)malloc(sizeof(char) * num);时,p和str的值是相同的,都是NULL,即都指向0地址。

2、当GetMemory申请到内存空间后,其只是将申请到的内存空间的编号存到p中了,即只是赋值给p了,就是说p指向了刚刚申请到的内存区域。

3、显然,GetMemory(str, 100);执行过后,str的值是没有改变的,就是说str还是指向0地址。

那么怎么改,可达到当初的设计意愿呢?

方法一、

void GetMemory(char *&p, int num)
{
	p = (char *)malloc(sizeof(char) * num);
}

void main(void)
{
	char *str = NULL;
	GetMemory(str, 100);
    strcpy(str, "Hello");
}

方法二、

void GetMemory(char **p, int num)
{
	*p = (char *)malloc(sizeof(char) * num);
}

void main(void)
{
	char *str = NULL;
	GetMemory(&str, 100);
    strcpy(str, "Hello");
}


对比这两种方法,第一种方法改动比较小,其利用引用的特性。第二种方法改动稍多点,且调用形式也变了。

方法一中:

p已经不再占用存储空间了,p是一个指针变量的引用,即在执行GetMemory(str, 100);时,p成了str的一个别名,在执行p = (char *)malloc(sizeof(char) * num);时,即已经改变了str的值,因为p是str的一个别名,故对p赋值,就是在对str赋值。

方法二中:

GetMemory中已经将p申明为二级指针了,所以main函数在执行调用时,传递的是str的地址,即p是指向str的,在执行*p = (char *)malloc(sizeof(char) * num);时,即改变了p所指向的变量,换句话说就是改变了str。

以上两种更改方法都达到了更改str的目的,也就是实现了程序最初的设计意愿。

 

 

 

 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值