1. java 中实参和形参的区别
形参和实参的特点
1、形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参有在函数内部有效。函数调用结束返回主调用函数后则不能再使用该形参变量。
2、实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使参数获得确定值。
3、实参和形参在数量上,类型上、顺序上应严格一致,否则就会发生类型不匹配的错误。
4、在一般传值调用的机制中只能把实参传送给形参,而不能把形参的值反向地传送给实参。因此在函数调用过程中,形参值发生改变,而实参中的值不会变化。而在引用调用的机制当中是将实参引用的地址传递给了形参,所以任何发生在形参上的改变实际上也发生在实参变量上
2. Java 值传递可以在方法内修改实参的值吗
不可以, 既然是值传递,那么在调用的时候,就已经完成了从实参到形参的复制,他们是两个完全不同的对象,只是值相同而已,我们没法通过形参去达到修改实参的目的,如果你喜欢,那么可以采用引用形式的形参。这个问题之前我也问过远标java导师,记得是这样回复我的。希望能帮助到你!
3. Java中的形参和实参的区别以及传值调用和传
1.形参:用来接收调用该方法时传递的参数。只有在被调用的时候才分配内存空间,一旦调用结束,就释放内存空间。因此仅仅在方法内有效。
2.实参:传递给被调用方法的值,预先创建并赋予确定值。
3.传值调用:传值调用中传递的参数为基本数据类型,参数视为形参。
4.传引用调用:传引用调用中,如果传递的参数是引用数据类型,参数视为实参。在调用的过程中,将实参的地址传递给了形参,形参上的改变都发生在实参上。
案例分析:
1.基础数据类型(传值调用)
传值,方法不会改变实参的值。
2.引用数据类型(引用调用)
传引用,方法体内改变形参引用,不会改变实参的引用,但有可能改变实参对象的属性值。
举两个例子:
(1)方法体内改变形参引用,但不会改变实参引用 ,实参值不变。
publicclassTestFun2{
publicstaticvoidtestStr(Stringstr){
str="hello";//型参指向字符串“hello”
}
publicstaticvoidmain(String[]args){
Strings="1";
TestFun2.testStr(s);
System.out.println("s="+s);//实参s引用没变,值也不变
}
}
执行结果打印:s=1
(2)方法体内,通过引用改变了实际参数对象的内容,注意是“内容”,引用还是不变的。
publicclassTestFun4{
(StringBuffersb){
sb.append("java");//改变了实参的内容
}
publicstaticvoidmain(String[]args){
StringBuffersb=newStringBuffer("my");
newTestFun4().testStringBuffer(sb);
System.out.println("sb="+sb.toString());//内容变化了
}
}
执行结果,打印:sb=my java 。
所以比较参数是String和StringBuffer 的两个例子就会理解什么是“改变实参对象内容”了。
总结:
1.java的基本数据类型是传值调用,对象引用类型是传引用。
2.当传值调用时,改变的是形参的值,并没有改变实参的值,实参的值可以传递给形参,但是,这个传递是单向的,形参不能传递回实参。
3.当引用调用时,如果参数是对象,无论对对象做了何种操作,都不会改变实参对象的引用,但是如果改变了对象的内容,就会改变实参对象的内容。
4. java中如何使形参改变实参
1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。
2.实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。
3.实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。
5. Java方法的形参是局部变量,不改变实际参数的值。
形参参考变量的分类可分为以下两大类(讨论范围:形参)
Primitive Formal Parameter(初始数据型,内建型-简单理解就是有前缀byte\short\int\long\float\double\char\boolean完全枚举的标识符,即我们通常所说的基本类型,不属于“类”,指向栈内存地址)
Reference Formal Parameter(引用型-简单理解就是无上述前缀的标识符,注意String类型非Primitive Data Type,属于“类”,指向堆内存地址)
PS:该死的是,String类型实例化创建对象并将对象引用赋值给一个变量时,竟然可以不用关键字new(跟Primitive 数据类型的赋予字面值方式在直观形式上几乎一致),故容易产生相关误区。
6. 形参不能改变实参,为什么在用指针传递数值的时候又可以改变呢
形参其实是在把实参传递给子函数的时候定义了一个新的变量,但是这个变量的值和实参相等
所以在子函数里
无论怎么修改都不会影响到调用它的函数的实参的值
在用指针做参数的时候
因为传递的不是值本身,而是它所对应的地址,我们改变值的时候是改变那个地址里的值
所以
传递指针的话
就能改变值了
如果你希望在子函数里可以修改调用它的函数的值的话你可以使用引用函数
就比如
#include<stdio.h>
void
fun(int
&x)
x
=
x
+
1;
void
main()
{
int
a
=
5;
fun(a);
printf("%d",a);
}
就是在参数前加了一个&就行了
7. 形式参数什么时候可以改变实参给个例子。
形参无法直接改变实参,只有通过指针来获得实参的存储地址。
然后通过地址来间接地对地址中实参的值进行操作。例如:
#include<stdio.h>
fun(int *c)
{
*c=*c+1;
}
main()
{
int a=1;
fun(&a);
printf("%d",a);
}
本例中主函数 main() 将 a 的地址赋给了自定义函数 fun()
然后自定义函数 fun() 通过对取 a 的地址中的值并加 1
最后又存储到 a 的地址中,实现了对实参 a 的改变!