欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Integer自動打包機制

系統(tǒng) 2200 0

轉載 http://hxraid.iteye.com/blog/614440

我們首先來看一段代碼:

Java代碼 復制代碼
  1. Integer?i= 100 ; ??
  2. Integer?j= 100 ; ??
  3. System.out.println(i==j);?? //true ??
  4. Integer?i= 200 ; ??
  5. Integer?j= 200 ; ??
  6. System.out.println(i==j);?? //false ??
    Integer i=100;
Integer j=100;
System.out.println(i==j);  //true
Integer i=200;
Integer j=200;
System.out.println(i==j);  //false
  

?

差不多的兩段代碼,怎么結果完全不同呢。我們分兩步來說明這個問題:

?

首先 Integer i=100; 編譯器會自動將int類型常數(shù)100包裝成Interger,采用的是Integer.valueOf(100); 這個方法。

?

然后我們看看valueOf(int)這個方法的源代碼:

Java代碼 復制代碼
  1. ? /* ?
  2. ??*?返回一個表示指定的?int?值的?Integer?實例。如果不需要新的?Integer?實例,則 ?
  3. ??*?通常應優(yōu)先使用該方法,而不是構造方法?Integer(int),因為該方法有可能通過 ?
  4. ??*?緩存經(jīng)常請求的值而顯著提高空間和時間性能。? ?
  5. ??*?@param??i?an?<code>int</code>?value. ?
  6. ??*?@return?a?<tt>Integer</tt>?instance?representing?<tt>i</tt>. ?
  7. ??*?@since??1.5 ?
  8. ??*/ ??
  9. public ? static ?Integer?valueOf( int ?i)?{ ??
  10. ?????? final ? int ?offset?=? 128 ; ??
  11. ?????? if ?(i?>=?- 128 ?&&?i?<=? 127 )?{? //?must?cache? ??
  12. ???????? return ?IntegerCache.cache[i?+?offset]; ??
  13. ?????} ??
  14. ????? return ? new ?Integer(i); ??
  15. } ??
  16. ??
  17. ? /* ?
  18. ??*?IntegerCache內(nèi)部類 ?
  19. ??*?其中cache[]數(shù)組用于存放從-128到127一共256個整數(shù) ?
  20. ??*/ ??
  21. private ? static ? class ?IntegerCache?{ ??
  22. ???? private ?IntegerCache(){} ??
  23. ??
  24. ???? static ? final ?Integer?cache[]?=? new ?Integer[-(- 128 )?+? 127 ?+? 1 ]; ??
  25. ??
  26. ???? static ?{ ??
  27. ???????? for ( int ?i?=? 0 ;?i?<?cache.length;?i++) ??
  28. ????????cache[i]?=? new ?Integer(i?-? 128 ); ??
  29. ????} ??
  30. }??
     /*
  * 返回一個表示指定的 int 值的 Integer 實例。如果不需要新的 Integer 實例,則
  * 通常應優(yōu)先使用該方法,而不是構造方法 Integer(int),因為該方法有可能通過
  * 緩存經(jīng)常請求的值而顯著提高空間和時間性能。 
  * @param  i an <code>int</code> value.
  * @return a <tt>Integer</tt> instance representing <tt>i</tt>.
  * @since  1.5
  */
public static Integer valueOf(int i) {
      final int offset = 128;
      if (i >= -128 && i <= 127) { // must cache 
	    return IntegerCache.cache[i + offset];
     }
     return new Integer(i);
}

 /*
  * IntegerCache內(nèi)部類
  * 其中cache[]數(shù)組用于存放從-128到127一共256個整數(shù)
  */
private static class IntegerCache {
	private IntegerCache(){}

	static final Integer cache[] = new Integer[-(-128) + 127 + 1];

	static {
	    for(int i = 0; i < cache.length; i++)
		cache[i] = new Integer(i - 128);
	}
}

  

?

原來如此, 當-128=<i<=127的時候,返回的是IntegerCache中的數(shù)組的值;當 i>127 或 i<-128 時,返回的是Integer類對象。 這就好解釋:

?

Java代碼 復制代碼
  1. Integer?i= 100 ; ??
  2. Integer?j= 100 ; ??
  3. System.out.println(i==j);?? //(1) ??
    Integer i=100;
Integer j=100;
System.out.println(i==j);  //(1)
  

此時的 i=IntegerCache.cache[228],因此 Integer引用i中存儲的是cache數(shù)組第228號元素的地址。同理j也是同一個cache數(shù)組的第228號元素的地址(因為cache是Integer的靜態(tài)數(shù)組,只有一個)。i==j比較的是引用地址,因此相等。

Java代碼 復制代碼
  1. Integer?i= 200 ; ??
  2. Integer?j= 200 ; ??
  3. System.out.println(i==j);?? //(2) ??
    Integer i=200;
Integer j=200;
System.out.println(i==j);  //(2)
  

此時的 i=new Integer(200);? 同樣j=new Integer(200) 。兩次都在堆中開辟了Integer的對象。i 和 j 中存儲的堆得對象地址是完全不同的。i==j 自然不相等了。

?

那么這樣做有什么意義呢? 我們來看看API的解釋:

Java代碼 復制代碼
  1. 返回一個表示指定的? int ?值的?Integer?實例。如果不需要新的?Integer?實例, ??
  2. 則通常應優(yōu)先使用該方法,而不是構造方法?Integer( int ),因為該方法有可能 ??
  3. 通過緩存經(jīng)常請求的值而顯著提高空間和時間性能。???
    返回一個表示指定的 int 值的 Integer 實例。如果不需要新的 Integer 實例,
則通常應優(yōu)先使用該方法,而不是構造方法 Integer(int),因為該方法有可能
通過緩存經(jīng)常請求的值而顯著提高空間和時間性能。 
  

假如我們在編程時大量需要值為100的Integer對象,如果只能通過new來創(chuàng)建的話。是不是需要在堆中開辟大量值一樣的Integer對象呢!這是相當不劃算的。既然如此,Java中的字符串常量池的應用是不是可以提醒我們點什么呢?是的, IntegerCache.cache就相當于這樣一個字符串常量池。 當我們需要Integer i=100的時候,直接從cache中取出第[100+128]號元素的地址賦值引用i,再次需要Integer j=100時,還是直接去這個地址賦給j ..... 是不是省去了再堆中不停的創(chuàng)建對象的代價了(空間,時間上的消耗都很大)。

Integer自動打包機制


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 一区二区三区免费在线观看 | 草久视频在线 | 国产毛片a级 | 91久操 | 欧美日韩精品一区二区在线播放 | 曰本一级毛片免费 | wwwxxx日本在线观看 | 免费高清精品国偷自产在线 | 2014亚洲天堂 | 国产精品主播视频 | 国内精品免费一区二区观看 | 夜夜爽天天狠狠九月婷婷 | 三级免费黄色片 | japanese末成年free | 国产成人精品久久二区二区 | 日韩精品资源 | 91久久久久久久久久久 | 亚洲AV久久无码精品九九九小说 | 欧美日韩一区二区三区在线观看 | 男女配种超爽免费视频 | 亚洲精品无码成人A片九色播放 | 国产午夜视频在线 | 亚洲色图88 | 久久久久久亚洲精品 | 色综合色综合网色综合 | 久久亚洲精品国产精品777777 | 激情婷婷小说 | 狠狠综合久久av一区二区小说 | 一级在线观看 | 欧美18xxxx | 亚洲一区视频在线 | 哥斯拉大战金刚2在线观看免费完整版 | 夜夜视频 | 啪啪网免费| 一级在线播放 | 精品欧美乱码久久久久久 | 老司机免费福利视频无毒午夜 | 9l蝌蚪porny中文自拍 | 午夜社区 | 欧美在线观看视频一区 | 天天草天天干天天 |