基本数据类型传递的是值的拷贝;对象类型传递的是引用的拷贝;而String类型传递的虽然也是对象,但它不同于一般的对象类型,它String被设计为不可修改的类型,也就是对String对象的任何修改都将重新创建一个对象而放弃以前的内存空间的引用!
public class Example{
String str=new String("good");
char[]ch={'a','b','c'};
public static void main(String args[]){
Example ex=new Example();
ex.change(ex.str,ex.ch);
System.out.print(ex.str+" and ");
System.out.print(ex.ch);
}
public void change(String str,char ch[]){
str="test ok";
ch[0]='g';
}
}
结果: good and gbc
class Str
{
public static void main(String[] args)
{
int i = 900;
System.out.println(i);
changeInt(i);
System.Out.println(i);
}
public static void changeInt(int s)
{
s = 34234;
}
}
结果:
900
900
class Str
{
public static void main(String[] args)
{
Yinyong y = new Yinyong();
System.Out.println(y.age);
changeObject(y);
System.Out.println(y.age);
}
public static void changeObject(Yinyong obj)
{
Obj.age = 34234;
}
}
class Yinyong
{
int age = 22;
}
结果:
22
34234
class Str
{
public static void main(String[] args)
{
String s = "java test";
System.Out.println(s);
changeString(s);
System.out.println(s);
}
public static void changeString(String str)
{
str = "3gg over right";
}
}
结果:
java test
java test
String被设计为不可修改的类型,也就是对String对象的任何修改都将重新创建一个对象而放弃以前的内存空间的引用!
如上例:
比如 s指向0x2344, 当它赋值给str时str也同样指向了0x2344。而当 执行str=”3gg over right”后,str指向了别的地方。也许是
0x2222或者其他,反正不是0x2344了。所以当你输出s的时候,它的值并没有被修改!
按值传递是指的是在方法调用时,传递的参数是按值的拷贝传递
按引用传递是指的是在方法调用时,传递的参数是按引用进行传递,其实传递的引用的地址,也就是变量所对应的内存空间的地址。