java中都是值传递而不是引用传递。举个例子:当代码为如下时
public static void modifyPoint(Point pt ,int j){
pt = new Point(20,20);
j=15;
System.out.println("1pt "+pt+" j= "+j);
}
public static void main(String[] arge){
Point pt = new Point(10, 10);
int j=10;
System.out.println("2pt "+pt+" j= "+j);
modifyPoint(pt, j);
System.out.println("3pt "+pt+" j= "+j);
}
输出的结果为:
2pt java.awt.Point[x=10,y=10] j= 10
1pt java.awt.Point[x=20,y=20] j= 15
3pt java.awt.Point[x=10,y=10] j= 10
当代码为如下时:
public static void modifyPoint(Point pt ,int j){
pt.setLocation(5, 5);
//pt = new Point(20,20);
j=15;
System.out.println("1pt "+pt+" j= "+j);
}
public static void main(String[] arge){
Point pt = new Point(10, 10);
int j=10;
System.out.println("2pt "+pt+" j= "+j);
modifyPoint(pt, j);
System.out.println("3pt "+pt+" j= "+j);
}
输出结果为:
2pt java.awt.Point[x=10,y=10] j= 10
1pt java.awt.Point[x=5,y=5] j= 15
3pt java.awt.Point[x=5,y=5] j= 10
为什么在modifyPoint方法中修改了j的值但是面试打印的结果还是10呢?因为java中是值传递,modifyPoint方法中的j只是main中j的一个副本 当你修改副本对原始的j当然没有影响。那有人就会问了 为什么在setLocation()中设置了point的值就有效呢?其实modifyPoint方法操作是point对象的引用的副本而非point的对象的副本,如下图: