一、实参和形参
先扯一段代码
public static void swap(int a,int b) {
int tmp = a;
a = b;
b = tmp;
System.out.println("swap方法中,a的值是"+a+",b的值是"+b);
}
public static void main(String[] args) {
int a = 6;
int b = 9;
swap(a,b); // swap方法中,a的值是9,b的值是6
System.out.println("交换结束后,a的值是"+a+",b的值是"+b); // 交换结束后,a的值是6,b的值是9
// 传参数相当于复制,swap中的a、b是复制品
}
嗯,就这个,swap(int a,int b)这个里头的a,b就是形参,,然后main方法里头的a,b就是实参了。那么问题来了,为啥这样子呢。下面上专业的解释:
形参
定义:全称"形式参数",用于定义方法的时候使用的参数,目的用来接收调用该方法时传递的参数。
说明:只有在被调用时才会分配内存单元,在调用结束,即刻释放所分配的内存单元。因此,只在方法内才有效。
实参
定义:全称"实际参数",用于调用时传递给方法的参数,即传递给被调用方法的值。
说明:预先创建并赋予确定值。
1、形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只在函数内部有效。函数调用结束返回主调用函数后则不能再使用该形参变量。
2、实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使参数获得确定值。
3、实参和形参在数量上,类型上、顺序上应严格一致,否则就会发生类型不匹配的错误。
4、在一般传值调用的机制中只能把实参传送给形参,而不能把形参的值反向地传送给实参。因此在函数调用过程中,形参值发生改变,而实参中的值不会变化。而在引用调用的机制当中是将实参引用的地址传递给了形参,所以任何发生在形参上的改变实际上也发生在实参变量上。
嗯,大概就是上面解释的一样,就这么回事,嗯,没毛病,下面是图解:
嗯,大概就这么个回事
二、值传递和引用传递
还是刚那个代码
public static void swap(int a,int b) {
int tmp = a;
a = b;
b = tmp;
System.out.println("swap方法中,a的值是"+a+",b的值是"+b);
}
public static void main(String[] args) {
int a = 6;
int b = 9;
swap(a,b); // swap方法中,a的值是9,b的值是6
System.out.println("交换结束后,a的值是"+a+",b的值是"+b); // 交换结束后,a的值是6,b的值是9
// 传参数相当于复制,swap中的a、b是复制品
}
这个就是值传递,就只是传递的是值
public class DataWrap {
int a;
int b;
}
public class Test{ // 引用传递
public static void swap(DataWrap dw) { // 复制一个dw的引用,指向对象
int tmp = dw.a;
dw.a = dw.b;
dw.b = tmp;
System.out.println("swap方法中,a的值是"+dw.a+",b的值是"+dw.b);
dw = null; // 把它杀掉
}
public static void main(String[] args) {
DataWrap dw = new DataWrap();
dw.a = 6;
dw.b = 9;
swap(dw);//swap方法中,a的值是9,b的值是6
System.out.println("交换结束后,a的值是"+dw.a+",b的值是"+dw.b);//swap方法中,a的值是9,b的值是6
}
}
这个就是引用传递,传递的是内存地址,内存地址所指向的内容如果变了,内容也会跟着变的