java 形参和实参_Java——形参和实参的区别

本文解析了形参和实参在函数调用中的区别与作用,通过Exchg函数示例详细说明了数据单向传递及指针类型参数的特殊性,以及如何正确交换变量值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

形参出现在函数定义中,在整个函数体内都可以使用,离开该函数则不能使用。

实参出现在主调函数中,进入被调函数后,实参变量也不能使用。

形参和实参的功能是作数据传送。发生函数调用时,主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。

1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。

2.实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。

3.实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。

4.函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。

5.当形参和实参不是指针类型时,在该函数运行时,形参和实参是不同的变量,他们在内存中位于不同的位置,形参将实参的内容复制一份,在该函数运行结束的时候形参被释放,而实参内容不会改变。

如果函数的参数是指针类型变量,在调用该函数的过程中,传给函数的是实参的地址,在函数体内部使用的也是实参的地址,即使用的就是实参本身。所以在函数体内部可以改变实参的值。

转自:http://blog.163.com/zhengguo_li/blog/static/703014802013423501214/

形参:全称为"形式参数"是在定义函数名和函数体的时候使用的参数,目的是用来接收调用该函数时传如的参数.

实参:全称为"实际参数"是在调用时传递个该函数的参数.

void Exchg1(int x, inty)

{inttmp;

tmp=x;

x=y;

y=tmp;

printf("Exchg1:x=%d,y=%d\n",x,y);

}void Exchg2(int &x, int &y)

{inttmp;

tmp=x;

x=y;

y=tmp;

printf("Exchg2:x=%d,y=%d\n",x,y);

}void Exchg3(int *x, int *y)

{inttmp;

tmp=*x;*x=*y;*y=tmp;

printf("Exchg3:x=%d,y=%d\n",*x,*y);

}voidmain()

{int a=4,b=6;

Exchg1 (a,b) ;

printf("a=%d,b=%d\n",a,b);

Exchg2 (a,b);

printf("a=%d,b=%d\n",a,b);

Exchg3(&a,&b) ;

printf("a=%d,b=%d\n",a,b);

}

这里Exchg1函数被调用的时候,并没有成功交换a跟b的数据。为何呢。

int a=4,b=6;   Exchg1 (a,b) ; //这里本质上发生的是:Exchg1 (intx=a,int y=b) ;   x跟y是函数定义里面的形参,也就是说这里只是把实参a跟b的值赋予了x,y这2个形参变量。接下来,函数里发生的值互换只换掉了x跟y的值,而实参a跟b没有影响。

Exchg2 (a,b); //再看本质Exchg2 (int &x=a,int &y=b);   这里x跟y都是a,b的引用,操作x跟y交换就等于a跟b交换,自然,调用Exchg2 可以成功交换a跟b

Exchg3(&a,&b) ; //Exchg3(int *x=&a,int *y=&b);   x跟y2个形参是a跟b的指针,也就是实参数据存放的地址。然后函数里交换了x跟y指向的数据,也就是实参a跟b,所以,交换也是成功的。

代码运行的结果,exchg1没有交换a,b值;exchg2交换了a,b值,到了exchg,a,b的值似乎没有交换,仍旧是a为4,b为6,刚开始以为代码有问题,后来设置了断点之后,发现代码运行到exchg3(&a,&b)时,a=6,b=4了,所以代码运行结果和初始值一样的话,说明已经交换了a,b的值,至此说明代码是没有任何问题的。

转自:http://blog.sina.com.cn/s/blog_58c3f7960100ptri.html

<think>我们正在讨论C++中形参实参区别。根据引用内容,我们可以总结以下几点: 1.形参是函数定义时声明的参数,实参是函数调用时传入的实际值。2.形参只在函数内部有效,函数调用结束后释放内存。3.实参必须有确定的值,并且在数量、类型、顺序上必须与形参一致(除非有类型转换)。 4.参数传递默认是单向的值传递(复制实参的值给形参),因此形参的改变不会影响实参(除非使用指针或引用)。注意:引用中提到了C++有三种参数传递方式:值传递、引用传递指针传递。其中值传递不会改变实参,而引用传递指针传递可以改变实参。 下面我们按照用户要求,用中文回答,并注意LaTeX格式。</think>### C++函数参数传递:形参实参区别 在C++函数调用中,**形参**(形式参数)**实参**(实际参数)是函数参数传递的核心概念,主要区别如下: #### 1. **定义与作用域** - **形参**:函数声明或定义时指定的变量,如`void func(int param)`中的`param` - 仅在函数内部有效,函数调用时分配内存,调用结束后立即释放[^1] - 作用域限定在函数体内,不能在外部使用 - **实参**:函数调用时传入的具体值或变量,如`func(5)`中的`5` - 可以是常量、变量、表达式或函数返回值[^1] - 必须在调用前具有确定值 #### 2. **内存与生命周期** - 形参实参的**临时副本**:函数调用时,系统为形参分配独立内存空间,将实参的值复制到形参中[^2] - 典型内存关系: $$ \text{实参内存地址} \neq \text{形参内存地址} $$ - 调用结束后形参内存被释放,实参内存保持不变[^2] #### 3. **数据传递方式** - **值传递(默认)**:单向传递,实参形参 ```cpp void swap(int a, int b) { int tmp = a; a = b; b = tmp; // 仅修改形参 } int main() { int x=1, y=2; swap(x, y); // 调用后x=1, y=2(实参未变) } ``` - **指针传递**:通过地址间接修改实参 ```cpp void swap(int* a, int* b) { int tmp = *a; *a = *b; *b = tmp; // 修改实参内存 } ``` - **引用传递(C++特有)**:形参实参的别名 ```cpp void swap(int &a, int &b) { // 形参为引用 int tmp = a; a = b; b = tmp; // 直接修改实参 } ``` #### 4. **关键区别总结** | 特性 | 形参 | 实参 | |--------------|--------------------------|--------------------------| | **定义位置** | 函数声明/定义 | 函数调用处 | | **内存分配** | 调用时创建,结束时释放 | 已存在 | | **数据流向** | 接收实参值(默认单向) | 提供初始值 | | **修改影响** | 不影响实参(值传递时) | 可被指针/引用修改 | > ⚠️ **类型匹配要求**: > 实参形参必须在数量、类型、顺序上严格一致(若可自动转换则允许类型差异)[^1]。例如: > $$ \text{func(float)} \ \text{可接受} \ \text{func(3)} \quad (\text{int} \to \text{float转换}) $$ #### 5. **本质区别图示** ```mermaid graph LR A[实参] -->|值传递| B[形参副本] A -->|指针传递| C[指向实参的指针] A -->|引用传递| D[实参的别名] ``` 理解这些区别对避免逻辑错误至关重要,例如值传递时误以为形参修改会影响实参[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值