public class TestMain { public static void main(String[] args) { List<Integer> list = new ArrayList<Integer>(); for (int i = 0; i < 10; i++) { list.add(i); } add(list); for (Integer j : list) { System.err.print(j+",");; } System.err.println(""); System.err.println("*********************"); String a="A"; append(a); System.err.println(a); int num = 5; addNum(num); System.err.println(num); } static void add(List<Integer> list){ list.add(100); } static void append(String str){ str+="is a"; } static void addNum(int a){ a=a+10; } }
打印出来的结果是:
0,1,2,3,4,5,6,7,8,9,100,
*********************
A
5java
一:搞清楚 基本类型 和 引用类型的不一样之处
int num = 10; String str = "hello";
如图所示,num是基本类型,值就直接保存在变量中。而str是引用类型,变量中保存的只是实际对象的地址。通常称这种变量为"引用",引用指向实际对象,实际对象中保存着内容。
二:搞清楚赋值运算符(=)的做用windows
num = 20; str = "java";
对于基本类型 num ,赋值运算符会直接改变变量的值,原来的值被覆盖掉。
对于引用类型 str,赋值运算符会改变引用中所保存的地址,原来的地址被覆盖掉。可是原来的对象不会被改变(重要)。
如上图所示,"hello" 字符串对象没有被改变。(没有被任何引用所指向的对象是垃圾,会被垃圾回收器回收)
三:调用方法时发生了什么?参数传递基本上就是赋值操做。app
第一个例子:基本类型 void foo(int value) { value = 100; } foo(num); // num 没有被改变 第二个例子:没有提供改变自身方法的引用类型 void foo(String text) { text = "windows"; } foo(str); // str 也没有被改变 第三个例子:提供了改变自身方法的引用类型 StringBuilder sb = new StringBuilder("iphone"); void foo(StringBuilder builder) { builder.append("4"); } foo(sb); // sb 被改变了,变成了"iphone4"。 第四个例子:提供了改变自身方法的引用类型,可是不使用,而是使用赋值运算符。 StringBuilder sb = new StringBuilder("iphone"); void foo(StringBuilder builder) { builder = new StringBuilder("ipad"); } foo(sb); // sb 没有被改变,仍是 "iphone"。
重点理解为何,第三个例子和第四个例子结果不一样?
下面是第三个例子的图解:
builder.append("4")以后
下面是第四个例子的图解:
builder = new StringBuilder("ipad"); 以后
iphone