一. final
final類不能被繼承,沒有子類,final類中的方法預設是final的。
final方法不能被子類的方法覆蓋,但可以被繼承。
final成員變數表示常量,只能被賦值一次,賦值後值不再改變。
final不能用於修飾構造方法。
父類的private成員方法是不能被子類方法覆蓋的,因此private型別的方法預設是final型別的。
1. final類
如果乙個類不允許其子類覆蓋某個方法,則可以把這個方法宣告為final方法。
使用final方法的原因有二:
第一、把方法鎖定,防止任何繼承類修改它的意義和實現。
第二、高效。編譯器在遇到呼叫final方法時候會轉入內嵌機制,大大提高執行效率。
例如:
package com.cmos.adapter.service;
public class test
public void f1()
//無法被子類覆蓋的方法
public final void f2()
public void f3()
private void f4()
}package com.cmos.adapter.service;
public class test2 extends test
public static void main(string args)
}
執行結果:
2. finall變數
用final修飾的成員變數表示常量,值一旦給定就無法改變!
final修飾的變數有三種:靜態變數、例項變數和區域性變數,分別表示三種型別的常量。
從下面的例子中可以看出,一旦給final變數初值後,值就不能再改變了。
另外,final變數定義的時候,可以先宣告,而不給初值,這中變數也稱為final空白,無論什麼情況,編譯器都確保空白final在使用之前必須被初始化。但是,final空白在final關鍵字final的使用上提供了更大的靈活性,為此,乙個類中的final資料成員就可以實現依物件而有所不同,卻有保持其恆定不變的特徵。
public class test2
/*** @param args
*/public static void main(string args)
private void test()
public void test2()
}
執行結果
3. final引數
當函式引數為
final
型別時,你可以讀取使用該引數,但是無法改變該引數的值。
public class test2
public void f1(final int i)
}
執行結果:
特別要注意乙個問題:
對於被static和final修飾過的例項常量,例項本身不能再改變了,但對於一些容器型別(比如,arraylist、hashmap)的例項變數,不可以改變容器變數本身,但可以修改容器中存放的物件,這一點在程式設計中用到很多。
public class teststaticfinal
public static void main(string args)
}
java中this關鍵字
1 this 關鍵字 疑問 建立的p 物件為什麼沒有值。解答 name 與age 在指定的建構函式裡面已經存在,當name name 這個語句執行的時候,如果jvm 在該方法內能尋找到該變數,則不會去尋找成員變數,那麼要想指定給成員變數或物件的屬性進行初始化賦值,那麼必須指定name 是成員屬性。1...
static關鍵字 java關鍵字
先按照宣告順序初始化基類靜態變數和靜態 塊,接著按照宣告順序初始化子類靜態變數和靜態 塊,而後按照宣告順序初始化基類普通變數和普通 塊,然後執行基類建構函式,接著按照宣告順序初始化子類普通變數和普通 塊,最後執行子類建構函式。import static com.test.test1.fu.say i...
Java中的關鍵字
abstract 抽象的 continue 繼續 for 當 的時候 new 新建 switch 轉換 assert 斷言 default 預設 if 如果 package 打包 synchronized 同步 boolean 布林 do 做 goto 跳轉到 private 私有的 this 這個...