我们假设一个场景来理解函数调用时候形参和实参的内存分配,过年了,你的一个压岁钱来自于你姑姑给了你100块钱。
先看这一段代码:
#include <stdio.h>
void earn(int money)
{
money += 100;
}
int main()
{
int money=0;
earn(money);
printf("I have %d money", money);
return 0;
}
//打印结果为I have 0 money
这时候你发现你的压岁钱不见了,这钱是不是让内存给吃了?
其实还真的是,函数调用中的形参在调用时分配内存,调用结束后又被回收。也就是当执行earn(money);
的时候,重新开辟了一块跟money
变量一样大小的内存,即形参的内存,当函数调用结束后该内存又被回收,相当于过年时候你姑姑给了你压岁钱,然后又被你爸妈拿回去给你姑姑的孩子。earn
函数中修改的只是形参的值,而不是实参的值。所以实际上实参的值并没有发生改变,仍然为0
那么如何直接改变实参的值,方法有两种:
方法一:直接传递指针
#include <stdio.h>
void earn(int *money)
{
*money += 100;
}
int main()
{
int money=0;
earn(&money);
printf("I have %d money", money);
return 0;
}
//打印结果为I have 100 money
方法二:赋值给实参
#include <stdio.h>
int earn(int money)
{
return money += 100;
}
int main()
{
int money=0;
money = earn(money);
printf("I have %d money", money);
return 0;
}
//打印结果为I have 100 money