觀察情況一(字元串實例直接賦值給string類型的變數): 分析: 通過調試看出,兩個變數存儲的記憶體地址是一樣的,這個記憶體地址其實指向的是字元串常量區 圖解: 原理: 創建一個字元串對象,系統會先掃描常量區有沒有相同值的字元串,如果有,就直接返回常量區對應的地址 。 觀察情況二(通過 new 關鍵字 ...
觀察情況一(字元串實例直接賦值給string類型的變數):
分析:
通過調試看出,兩個變數存儲的記憶體地址是一樣的,這個記憶體地址其實指向的是字元串常量區
圖解:
原理:
創建一個字元串對象,系統會先掃描常量區有沒有相同值的字元串,如果有,就直接返回常量區對應的地址 。
觀察情況二(通過 new 關鍵字實例化string類型的對象):
分析:
此時為什麼使用new關鍵字創建字元串實例,怎麼記憶體地址沒有像情況一中記憶體地址都一樣。原因是new關鍵字的本質促使。
new的作用:
1.開闢堆記憶體空間或者常量區
2.創建對象
3.調用構造函數
4.返回開闢的記憶體地址
由此分析new,是開闢了新的記憶體區域,自然返回的記憶體地址也不會一樣。
觀察情況三:
思考:
從正常邏輯分析,a和b指向了同一個對象的引用,案例b="bb";後變數a的值也應該發生改變才對。由於是根據字元串特性的不同,這裡才使a得值沒有發生變化。
圖解:
原理:
如果對一個字元串類型的變數的內容進行修改,其實是無法修改變數存儲的字元串本身的,而是根據這個新的字元串,去掃描常量區,如果沒有就開闢新的空間存儲這個字元串,並返回新的記憶體空間地址。
字元串本質總結:
1. 創建一個字元串,系統會先掃描常量區有沒有相同值的字元串,如果有,就直接返回常量區對應的地址 。
2. 如果對一個字元串類型的變數的內容進行修改,其實是無法修改變數存儲的字元串本身的,而是根據這個新的字元串,去掃描常量區,如果沒有就開闢新的空間存儲這個字元串,並返回新的記憶體空間地址。
3.字元串具有恆定性(值不能改)的特點,一旦在常量區中創建,生命周期是隨著應用程式結束而釋放。
4.字元串存儲在常量區中,作用域是一個公共的區域。
面試實戰題目:
不是說字元串是不可變的嗎?string s="abc";s="123"不就是變了嗎?
答:
在這裡,變數s的存儲的值確實是由"abc"變成"123"。但是這僅僅改變的是變數s所指向的不同引用。"abc"是一個字元串實例對象,
"abc"的創建首先會掃描堆區域中的常量區,有沒有"abc",如果有則直接返回地址,如果沒有則開闢一塊新的區域,並返回新的地址。
根據字元串的恆定性,一旦在常量區中創建,生命周期是隨著應用程式結束而釋放。
所以當創建"123"時,沒有改變"abc"。