Java中的“ final”關鍵字如何工作?(我仍然可以修改對象)
你總是允許初始化一個final變量。編譯器確保你只能執行一次。
請注意,對存儲在final變量中的對象的調用方法與的語義無關final。換句話說:final僅與引用本身有關,而與引用對象的內容無關。
Java沒有對象不變性的概念。這是通過精心設計對象來實現的,這是一項艱巨的工作。
這是一個最喜歡的面試問題。帶著這些問題,訪問者試圖找出你對對象的構造,方法,類變量(靜態變量)和實例變量的理解程度。
import java.util.ArrayList;import java.util.List;class Test { private final List foo; public test() {foo = new ArrayList();foo.add('foo'); // Modification-1 } public void setFoo(List foo) { //this.foo = foo; Results in compile time error. }}
在上述情況下,我們為“ Test”定義了一個構造函數,并為其指定了“ setFoo”方法。
關于構造器: 構造函數可以調用只有一個使用每個對象的創建時間new關鍵字。你不能多次調用構造函數,因為構造函數的目的不是這樣做的。
關于方法:可以根據需要多次調用方法(甚至永遠不會調用),并且編譯器知道該方法。
場景1
private final List foo; // 1
foo是實例變量。當我們創建Test類對象時,實例變量foo將被復制到Test類對象中。如果我們foo在構造函數內部分配,則編譯器知道構造函數將僅被調用一次,因此在構造函數內部分配它沒有問題。
如果我們foo在一個方法內部賦值,編譯器就會知道一個方法可以被多次調用,這意味著必須多次更改該值,而final變量是不允許的。因此編譯器認為構造函數是一個不錯的選擇!你只能一次將值分配給最終變量。
方案2
private static final List foo = new ArrayList();
foo現在是一個靜態變量。當我們創建Test類的實例時,foo不會被復制到對象,因為它foo是靜態的。現在foo不是每個對象的獨立屬性。這是Test類的屬性。但是foo可以被多個對象看到,如果每個使用new關鍵字創建的對象最終將調用Test構造函數,則該構造函數會在創建多個對象時更改值(記住static foo并不是在每個對象中都復制,而是在多個對象之間共享)
場景3
t.foo.add('bar'); // Modification-2
以上Modification-2是你的問題。在上述情況下,你沒有更改第一個引用的對象,而是在foo其中添加了允許的內容。如果你嘗試將a分配new ArrayList()給foo引用變量,則編譯器會抱怨。規則如果已初始化final變量,則無法將其更改為引用其他對象。(在這種情況下ArrayList)
final類不能被子類化final方法不能被覆蓋。(此方法在超類中)最終方法可以重寫。(以語法方式閱讀。此方法在子類中)
解決方法在Java中,我們使用final帶有變量的關鍵字來指定其值不被更改。但是我看到你可以在類的構造函數/方法中更改值。同樣,如果變量是static,則為編譯錯誤。
這是代碼:
import java.util.ArrayList;import java.util.List;class Test { private final List foo; public Test() { foo = new ArrayList(); foo.add("foo"); // Modification-1 } public static void main(String[] args) { Test t = new Test(); t.foo.add("bar"); // Modification-2 System.out.println("print - " + t.foo); }}
上面的代碼工作正常,沒有錯誤。
現在將變量更改為static:
private static final List foo;
現在是編譯錯誤。這final真的如何運作?
相關文章:
1. windows7 ping不通虛擬機VMware上的linux(ubuntu)的ip2. 網頁爬蟲 - python 爬取網站 并解析非json內容3. node.js - nodejs開發中常用的連接mysql的庫4. python - 我在使用pip install -r requirements.txt下載時,為什么部分能下載,部分不能下載5. mysql - jdbc的問題6. python - 編碼問題求助7. 視頻文件不能播放,怎么辦?8. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處9. python - 數據與循環次數對應不上10. mysql - 如何減少使用或者不用LEFT JOIN查詢?
