实参和形参的传递java_c语言的形参和实参传递的区别详解

本文详细介绍了C语言和Java中参数传递的三种方式:值传递、地址传递和引用传递,并通过示例代码展示了它们在实际操作中的区别。在C语言中,实参和形参间是单向值传递;而在Java中,参数传递类似引用传递,对形参的修改会直接影响到实参。
摘要由CSDN通过智能技术生成

参数传递,是在程序运行过程中,实际参数就会将参数值传递给相应的形式参数,然后在函数中实现对数据处理和返回的过程。参数传递有3种方式:

值传递

地址传递

引用传递

tips:

被调用函数的形参只有函数被调用时才会临时分配存储单元,一旦调用结束占用的内存便会被释放

值传递和地址传递,传递的都是实参的一个拷贝

C语言中实参和形参之间的数据传递是单向的“值传递”,单向传递,只能由实参传给形参,反之不行

输出格式并没有选择%p而是选择了%d,因为十进制的数看起来更直观

1 值传递

如果只是传递值的话:

#include

//值传递:传值

void swap( int x, int y);

int main()

{

int a=2,b=3;

printf("before:实参为a,b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

swap(a,b);

printf("after:实参为a,b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

return 0;

}

void swap(int x,int y)

{

int tmp;

tmp=x;

x=y;

y=tmp;

printf("inside:形参为x,y\nx=%d,地址为%d\ny=%d,地址为%d\n\n",x,&x,y,&y);

}

执行结果:从形参x和y的地址来看,传递的是实参a和b的拷贝。对拷贝的修改不会改变实参的值。。

d32c30831f3cddeec27b1842f158f812.png

如果值传递,传递的是地址呢?

#include

//值传递:传地址

void swap( int *x, int *y);

int main()

{

int a=2,b=3;

printf("before:实参为&a,&b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

swap(&a,&b);

printf("after:实参为&a,&b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

return 0;

}

void swap(int *x,int *y)

{

int *tmp= NULL;

tmp=x;

x=y;

y=tmp;

printf("inside:形参为*x,*y\n*x=%d,x=%d,地址为%d\n*y=%d,y=%d,地址为%d\n\n",*x,x,&x,*y,y,&y);

}

执行结果:形参是a和b的地址,但通过a和b的地址(即x和y)访问到的是a和b的拷贝。直接交换a和b的地址失败。

0139eaf0c3c2f334423fd119940e9932.png

2地址传递

#include

//地址传递

void swap( int *x, int *y);

int main()

{

int a=2,b=3;

printf("before:实参为&a,&b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

swap(&a,&b);

printf("after:实参为&a,&b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

return 0;

}

void swap(int *x,int *y)

{

int tmp;

tmp=*x;

*x=*y;

*y=tmp;

printf("inside:形参为*x,*y\n*x=%d,x=%d,地址为%d\n*y=%d,y=%d,地址为%d\n\n",*x,x,&x,*y,y,&y);

}

执行结果为: 形参是a和b的地址,但通过a和b的地址(即x和y)访问到的是a和b的拷贝。虽然不能直接交换a和b的地址,但是可以修改a和b的地址(即x和y)指向的值。也就是说,不能直接修改指针,但是可以修改指针指向的值。所以这一次a和b的值交换了。

cb2eb290d2719fed5fca127f9358cbd8.png

3 引用传递

#include

//引用传递

void swap( int &x, int &y);

int main()

{

int a=2,b=3;

printf("before:实参为a,b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

swap(a,b);

printf("after:实参为a,b\na=%d,地址为%d\nb=%d,地址为%d\n\n",a,&a,b,&b);

return 0;

}

void swap(int &x,int &y)

{

int tmp;

tmp=x;

x=y;

y=tmp;

printf("inside:形参为&x,&y\nx=%d,地址为%d\ny=%d,地址为%d\n\n",x,&x,y,&y);

}

void swap( int &x, int &y); //表示传递进去的是实参,而不是拷贝。

执行结果为: 传递的是实参,而不是实参的拷贝。对实参的修改,将会成功的改变其中的值。

418c97554e59406a0c6f5f9eb86f0613.png

补充

int x=1;

int *y=&x; //用于指针传递,y有自己独立的内存地址,存储的内容是x的地址,*y是x的值

int &z=x; //用于引用传递,可以理解为z就是x,x就是z,只不过名字不一样

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值