關于java中Int等類型裝箱時發生的奇怪現象
問題描述
各位朋友,我下面說一下我的理解,各位看看是否正確(注意不要瞎延伸,如果我對就告訴我說得是對的,讓我得到確認無誤。另外如果我錯了不要鄙視我,幫忙提出錯在哪并給出真正的答案是個好方法。我在知乎問問題有人把我鄙視的心理拔涼拔涼的了都):理解1:int,byte,short這幾個基本類型變量的裝箱操作,底層都有一個緩沖池(java源碼可以找到實現),也就是Object a=200; 這樣的操作,就會創建一個新對象裝下200,因為200超出了緩沖池。所以每次裝箱都new新的對象來包裝200.因此:Object a=200;與Object b=200; 判斷a==b返回false,因為其a和b不是指向同一個對象。而Object a =100與Object b=100 其a和b是指向同一個對象。(因為由于緩存池機制,導致裝箱的時候,只從池子中取一個值為100的對象返回,所以a和b地址相同,a==b返回true)理解2:同時,裝箱的int,byte,short有個不可變的特性(就像String類的對象也具有不可變的性質)。因此每次改變某個對象的值,都是去創建一個新的對象,而無法真正改變緩存池中這個對象本身。例如:
Object a=200;Object b=a; //現在a==b返回true
b=201; //想修改b指向的對象的值,但由于裝箱后的int,short以及String之類的那種不可變性,導致201是創建了一個新對象,把地址返回給b。而不是把原來那個200對象改為201.重復:在第二行,a和b是指向同一個對象,但是第三行修改b對象的時候,由于b對象的不可修改特性,導致最后結果是b是指向一個201的新對象,a還是指向200的那個對象。 也就是說裝箱后的基本類型不能再次被改變,只能創建新對象。(你有改變那個200對象本身的辦法嗎)理解3:以上的緩沖池和不可變性適用于String對象。(雖然String沒有裝箱,但是String的機制跟裝箱后的Integger差不多一樣)理解4:裝修后的int,short,byte。以及String類,都有一個辦法直接去創建新的對象,而不經過緩存池。那就是new。例如String a="123"; String b="123"; 這樣a和b都指向緩存池中的"123"而String a=new String("123"); 與 String b=new String("123");就不經過緩存池,直接創建了2個"123"的對象所以,a==b返回false。
問題解答
回答1:String是對象,沒有包裝器。
String a = '123';直接把引用指向常量池。而String b = new String(a);是把a的內容在堆中復制一份。
相關文章:
1. javascript - js中遞歸與for循環同時發生的時候,代碼的執行順序是怎樣的?2. 如何分別在Windows下用Winform項模板+C#,在MacOSX下用Cocos Application項目模板+Objective-C實現一個制作游戲的空的黑窗口?3. python - linux怎么在每天的凌晨2點執行一次這個log.py文件4. css3的背景圖片屬性有沒有把圖中這塊藍框區域(275*230)完整放在60*50區域?怎么寫呢5. java - new + 類名,一定需要申明一個對象嗎?6. android - 鍵盤遮擋RecyclerView7. javascript - jQuery each 方法第三個參數args 如何解釋?8. mysql數據庫每次查詢是一條線程嗎?9. javascript - 前端開發 本地靜態文件頻繁修改,預覽時的緩存怎么解決?10. 新手 - Python 爬蟲 問題 求助
