《Effective Java》读书笔记 Item 1:考虑静态工厂方法,而不是构造器
眾所周知,要想能獲取一個類的實例,該類得要提供一個public的構造器。但是《Effective Java》書中說還有一個方法,那就是提供靜態工廠方法(static factory method),該方法時靜態,同時可以根據參數返回一個類的實例。這里的靜態工廠方法(static factory method)和設計模式里的工廠方法(factory method)是不一樣的,我覺得工廠方法注重的是多態。
使用靜態工廠方法有利也有弊。
優點:
不像構造器那樣,靜態工廠方法擁有名字
靜態工廠方法是有名稱的,這樣就有了“可讀性”,看到方法的名稱就能知道能返回什么樣的實例。而對于構造器,通過提供參數,但是有時會讓人很迷惑,因為有時是因為傳遞的參數之不同而返回特定的實例,書中舉的例子是BigInteger(int, int, Random)這個構造器,如果想要返回一個素數,那么你就得傳入合適的參數進去,但是如果BigInteget中有個靜態方法是probablePrime,那么當開發者一看名字就很明白了,明白這個方法返回的是什么實例。有時一個類會有幾個構造器,每個構造器的參數個數相差一點點,或者是參數個數相等,但是各個參數的意義不同,有時是參數個數不等,這些情況下,當使用該類的開發人員在用構造器實例化時,會很苦惱,得去看文檔,知道每個參數的意義才行。
我覺得這一點是很實用的,在平時寫代碼時,我覺得得用上。
不像構造器那樣,每次調用都要創建對象
Boolean.valueOf(boolean)這個方法正體現了這一點,通過閱讀源代碼,可以發現在Boolean類里有TRUE和FALSE這兩個靜態字段。valueOf方法只是判斷傳來的參數值然后返回合適的對象(TRUE或FALSE),也就是說這兩個對象只是在Boolean類加載時創建,以后如果需要用到,就不要再重新創建,直接返回就行了。如果創建某個對象的代價相當可觀,那么這個方法的優點就很明顯了。不過的確是有不少情況,我們不需要重復地創建對象。
通過靜態工廠方法,我們還可以在每次調用時都返回同一個對象。singleton模式就是例子。
不像構造器那樣,靜態工廠方法可以返回類型的某個子類型
靜態工廠方法可以減少冗長的創建參數化類型時的代碼
當使用構造器創建參數類型時,我們要這樣做:
Map<String, List<String>> m = new HashMap<String, List<String>>();如果HashMap里有個方法時這樣的: public static <K, V> HashMap<K, V> newInstance() {
return new HashMap<K, V>();
}
那么我們便可以這樣創建實例: Map<String, List<String>> m = HashMap.newInstance();
不過現在還不能支持這樣的類型推導,不過總有一天會支持的吧。
缺點
一個類在僅提供靜態工廠方法,同時沒有公共或受保護的構造器時,此類是沒法被子類化的
在Collections Framework里就有這樣的例子。不過這也算是因禍得福吧,這樣我們可以盡量去通過組合(composition),而不是去通過繼承(inheritance)來解決某些問題。
靜態工廠方法和其他的靜態方法沒什么差別
總結
轉載于:https://www.cnblogs.com/Devfly/archive/2009/11/10/Consider-static-factory-methods-instead-of-constructors.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的《Effective Java》读书笔记 Item 1:考虑静态工厂方法,而不是构造器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Iterator作用
- 下一篇: 和朱晔一起复习Java并发(五):并发容