有時會遇到this做爲返回值的狀況,那麼此時返回的究竟是什麼呢?this
返回的是調用this所處方法的那個對象的引用,讀起來有點繞口哈,有沒有想起小學語文分析句子成份的試題,哈哈。3d
一點點分析的話,主幹是「返回的是引用」;cdn
什麼引用呢?「那個對象的引用」;對象
哪一個對象呢?「調用方法的那個對象」;blog
調用的哪一個方法呢?「調用的是this所位於的方法」;這樣就清楚了。內存
再總結一下就是,this做爲返回值時,返回的是調用某方法的對象的引用,這個方法正是包含「return this;」這行命令的那個方法;更簡單點說,就是誰調用返回的就是誰。it
爲了更清楚、直觀的理解問題,下面以簡單的例子說明。io
包human中定義了Person類,代碼以下:class
package human;test
public class Person { String name; int age;
public Person() {
} public Person(String n, String g) { name = n; gender = g; }
//test:this做返回值 Person reThis1() { Person per = new Person("lu","female"); System.out.println("reThis1 per:" + per.name); return this; } Person reThis2() { Person per = reThis1(); System.out.println("reThis2 per:" + per.name); return this; } Person reThis3() { name = "ma"; return this; } static void equRefer(Person per1, Person per2) { if(per1 == per2) System.out.println("per1指向的對象沒有改變,仍與per2指向同一個對象"); else System.out.println("per1指向的對象已改變,與per2指向不一樣的對象"); System.out.println("per1:" + per1.name); System.out.println("per2:" + per2.name); }
public static void main(String[] args) { Person per1 = new Person("liu","female"); Person per2 = per1;
per1 = per1.reThis1(); Person.equRefer(per1, per2);
per1 = per1.reThis2(); Person.equRefer(per1, per2);
System.out.println("調用reThis3以前,per1.name=" + per1.name); per1 = per1.reThis3(); System.out.println("調用reThis3以後,per1.name=" + per1.name); } } 輸出結果以下:
reThis1 per:lu per1指向的對象沒有改變,仍與per2指向同一個對象 per1:liu per2:liu reThis1 per:lu reThis2 per:liu per1指向的對象沒有改變,仍與per2指向同一個對象 per1:liu per2:liu 調用reThis3以前,per1.name=liu 調用reThis3以後,per1.name=ma 逐句分析執行過程:
(1).第1句:Person per1 = new Person("liu","female");
建立一個Person對象,將name初始化爲「liu」,gender初始化爲「female」,並讓per1指向該對象。
(2).第2句:Person per2 = per1;
定義一個Person類的對象引用,並與per1指向同一個對象;具體內存分配見圖1:
(3).第3句:per1 = per1.reThis1();
由per1調用reThis1()方法,並將返回值賦給per1;reThis1()方法體內定義了一個局部變量per,並建立一個對象,由per指向它;具體內存分配見圖2:
緊接着輸出reThis1 per:lu;最後返回this,並把返回的值賦給per1。
(4).第4句:Person.equRefer(per1, per2);
調用equRefer(per1,per2)來驗證per1的值並未改變;根據下面的輸出結果也可知per1仍與per2指向原來的對象,也就是說此時this的值與per1的值是一致的;也能夠說,誰調用的返回的就是誰。
輸出結果:
per1指向的對象沒有改變,仍與per2指向同一個對象 per1:liu per2:liu
此時的內存圖如圖3:
(5).第5句:per1 = per1.reThis2();
per1調用reThis2(),由(4)可推測,此時per1的值也不會變,是由per1調用的this所處的方法,因此返回的也是per1;具體來分析的話,reThis2()定義了一個局部變量per,並給其賦值爲reThis1(),也就是說reThis2()調用了reThis1(),由(3)、(4)可推知,此時的內存結構是下面這樣的:
局部變量per指向的對象與per1是一致的,由於調用reThis1的對象是per1所指的對象,因此返回值也是per1。
此處的輸出結果爲:
reThis1 per:lu reThis2 per:liu
(6).第6句:Person.equRefer(per1, per2);
驗證上面的結論,per1指向沒變,此時的內存分配圖如圖4所示:
(7).第七、八、9句:
System.out.println("調用reThis3以前,per1.name=" + per1.name); per1 = per1.reThis3(); System.out.println("調用reThis3以後,per1.name=" + per1.name);
per1調用reThis3();reThis3()中修改了namer的值,由"liu"改成"ma",而後返回this。
調用先後的內存結構分別如圖六、圖7所示:
輸出結果:
調用reThis3以前,per1.name=liu 調用reThis3以後,per1.name=ma
再一次驗證了上述的結論。
關於爲何使用this,我是這麼理解的:因爲定義類的時候還沒有建立對象,因此不能肯定對象到底叫什麼,就用this來統一表示,等到具體調用時就能夠知道對象的名字了,而後就用對象的引用替換this;因此爲了便於記憶,能夠理解成誰調用返回的就是誰。
至於返回this有什麼意義,個人理解是:記返回this的方法爲A,可能A的方法體中對對象的屬性作了某些操做或調用了某些方法完成了某些動做,總之,作完這些操做後就把原對象的引用返回,返回後的狀態是對象最新的狀態,可能與對象調用方法A前不一樣。