Java中的形参和实参的区别以及传值调用和传

Python040

Java中的形参和实参的区别以及传值调用和传,第1张

1.形参:用来接收调用该方法时传递的参数。只有在被调用的时候才分配内存空间,一旦调用结束,就释放内存空间。因此仅仅在方法内有效。

2.实参:传递给被调用方法的值,预先创建并赋予确定值。

3.传值调用:传值调用中传递的参数为基本数据类型,参数视为形参。

4.传引用调用:传引用调用中,如果传递的参数是引用数据类型,参数视为实参。在调用的过程中,将实参的地址传递给了形参,形参上的改变都发生在实参上。

案例分析:

1.基础数据类型(传值调用)

传值,方法不会改变实参的值。

2.引用数据类型(引用调用)

传引用,方法体内改变形参引用,不会改变实参的引用,但有可能改变实参对象的属性值。

举两个例子:

(1)方法体内改变形参引用,但不会改变实参引用 ,实参值不变。

public class TestFun2 {

public static void testStr(String str){

str="hello"//型参指向字符串 “hello”

}

public static void main(String[] args) {

String s="1" 

TestFun2.testStr(s)

System.out.println("s="+s) //实参s引用没变,值也不变

}

}

执行结果打印:s=1

(2)方法体内,通过引用改变了实际参数对象的内容,注意是“内容”,引用还是不变的。

public class TestFun4 {

public static void testStringBuffer(StringBuffer sb){

sb.append("java")//改变了实参的内容

}

public static void main(String[] args) {

StringBuffer sb= new StringBuffer("my ")

new TestFun4().testStringBuffer(sb)

System.out.println("sb="+sb.toString())//内容变化了

}

}

执行结果,打印:sb=my java 。

所以比较参数是String和StringBuffer 的两个例子就会理解什么是“改变实参对象内容”了。

总结:

1.java的基本数据类型是传值调用,对象引用类型是传引用。

2.当传值调用时,改变的是形参的值,并没有改变实参的值,实参的值可以传递给形参,但是,这个传递是单向的,形参不能传递回实参。

3.当引用调用时,如果参数是对象,无论对对象做了何种操作,都不会改变实参对象的引用,但是如果改变了对象的内容,就会改变实参对象的内容。

byval 传递的是行参,传递值 \x0d\x0a如 \x0d\x0aPublic Function getstr(ByVal str As String) As String \x0d\x0agetstr = str + ",ABC" \x0d\x0aEnd Function \x0d\x0a这个函数是把你传递近来的值加上",ABC"然后显示出来。是传递的值 \x0d\x0a调用:msgbox getstr("aaa") \x0d\x0a弹出对话框为aaa,ABC \x0d\x0a\x0d\x0aByRef 是实参 ,传递地址 \x0d\x0a在全局变量里声明一个字符型STR \x0d\x0adim str as string \x0d\x0a然后写一个过程 \x0d\x0aPublic Sub getstr1(ByRef str) \x0d\x0astr = "cccc" \x0d\x0aEnd Sub \x0d\x0a这个过程是改变全局变量的值。是按地址传递过来的 \x0d\x0a调用:call getstr1(str) \x0d\x0amsgbox str \x0d\x0a显示的是CCCC \x0d\x0a\x0d\x0a在C语言里的类似\x0d\x0a如函数\x0d\x0aFIND(INT X)\x0d\x0a这里的X就是形参,它也可以是表达式\x0d\x0a而实参呢是要传递给形参的如\x0d\x0aX=5\x0d\x0a5就是实参

这里主要涉及值传递和引用传递的区别,fun(int a)属于值传递,函数内部不会影响传进来参数的值;fun(int[],int,int)属于引用传递,实际上传入函数的并非数组每个数据的值,而是数组的地址,所以函数内容会直接影响数组的变化,建议你自己也可以多了解一下数据的引用类型和地址传递,这应该还是比较重要的