JAVA传递参数有两种方式:值传递和引用传递
值传递是传递数据:如基本数据类型都是值传递
引用传递是把形参和实参的指针指向了堆中的同一对象,对象的引用和数组的引用。
实参,Java的基本数据类型,如int,double等在函数的参数传递时,传递的是副本。String也属于这一范畴。
形参,而如果是对象,则传递的是引用。
如下代码实例:
public class MainActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
person p = new person();
p.name = "ken";
p.age = "12";
reset(p); // 传递的是p的指针地址,方法里面在对p的属性进行修改,方法结束后影响依然存在。
String name = p.name;
String age = p.age;
System.out.println(name + age);
// name=gg,age=223
setContentView(R.layout.main);
}
private void reset(person ap) {
ap.name="gg";
ap.age="223";
}
class person {
String name;
String age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
}
执行函数operater时,实际上在栈内存中又产生了一个新的变量,该变量是传入参数b的复制,这时候你可以理解成在栈内存中存在两个变量,一个是main方法中定义的b变量,一个是operater方法中定义的b变量的复制,两个变量都指向堆内存中存在的b的string对象, 然后方法中你执行 y=x;实际上只是改变了在operater中生成的b变量复制的值,b变量的值实际上并没有发生改变。
地址传递是它们共同占用一个存储空间,所以operater修改会影响到main
main中a,b传递的只是一个值,而他们本身的地址和值没有改变。
在main中
a => new StringBuffer("A");
b => new StringBuffer("B");
在test.operater(a, b);这句,传入的是两个引用
在operater方法中,b被重新赋值了,即引用地址改变了
================
补充一下:java中任何一个对象变量只是指向创建的对象的一个引用
例如 String a = "KKK"; 那么 “KKK”是创建的String对象, a 则是这个对象的引用,或者说a保存对象“KKK”在内存中的地址