Java設(shè)計模式(二) 工廠方法模式

原創(chuàng)文章,轉(zhuǎn)載請務(wù)必將下面這段話置于文章開頭處莉炉。
  本文轉(zhuǎn)發(fā)自Jason's Blog钓账,原文鏈接 
http://www.jasongj.com/design_pattern/factory_method/

工廠方法模式解決的問題

上文《簡單工廠模式不簡單》中提到,簡單工廠模式有如下缺點絮宁,而工廠方法模式可以解決這些問題

  • 由于工廠類集中了所有實例的創(chuàng)建邏輯梆暮,這就直接導(dǎo)致一旦這個工廠出了問題,所有的客戶端都會受到牽連绍昂。
  • 由于簡單工廠模式的產(chǎn)品是基于一個共同的抽象類或者接口啦粹,這樣一來,產(chǎn)品的種類增加的時候窘游,即有不同的產(chǎn)品接口或者抽象類的時候唠椭,工廠類就需要判斷何時創(chuàng)建何種接口的產(chǎn)品,這就和創(chuàng)建何種種類的產(chǎn)品相互混淆在了一起忍饰,違背了單一職責原則贪嫂,導(dǎo)致系統(tǒng)喪失靈活性和可維護性。
  • 簡單工廠模式違背了“開放-關(guān)閉原則”艾蓝,因為當我們新增加一個產(chǎn)品的時候必須修改工廠類力崇,相應(yīng)的工廠類就需要重新編譯一遍。
  • 簡單工廠模式由于使用了靜態(tài)工廠方法赢织,造成工廠角色無法形成基于繼承的等級結(jié)構(gòu)亮靴。

工廠方法模式

工廠方法模式介紹

工廠方法模式(Factory Method Pattern)又稱為工廠模式,也叫多態(tài)工廠模式或者虛擬構(gòu)造器模式于置。在工廠方法模式中台猴,工廠父類定義創(chuàng)建產(chǎn)品對象的公共接口,具體的工廠子類負責創(chuàng)建具體的產(chǎn)品對象俱两。每一個工廠子類負責創(chuàng)建一種具體產(chǎn)品。

工廠方法模式類圖

工廠模式類圖如下 (點擊可查看大圖)


Factory Method Pattern Class Diagram
Factory Method Pattern Class Diagram

工廠方法模式角色劃分

  • 抽象產(chǎn)品(或者產(chǎn)品接口)曹步,如上圖中IUserDao
  • 具體產(chǎn)品宪彩,如上圖中的MySQLUserDao,PostgreSQLUserDao和OracleUserDao
  • 抽象工廠(或者工廠接口)讲婚,如IFactory
  • 具體工廠尿孔,如MySQLFactory,PostgreSQLFactory和OracleFactory

工廠方法模式使用方式

如簡單工廠模式直接使用靜態(tài)工廠方法創(chuàng)建產(chǎn)品對象不同,在工廠方法活合,客戶端通過實例化具體的工廠類雏婶,并調(diào)用其創(chuàng)建實例接口創(chuàng)建具體產(chǎn)品類的實例。根據(jù)依賴倒置原則白指,具體工廠類的實例由工廠接口引用(客戶端依賴于抽象工廠而非具體工廠)留晚,具體產(chǎn)品的實例由產(chǎn)品接口引用(客戶端和工廠依賴于抽象產(chǎn)品而非具體產(chǎn)品)。具體調(diào)用代碼如下

package com.jasongj.client;

import com.jasongj.dao.IUserDao;
import com.jasongj.factory.IDaoFactory;
import com.jasongj.factory.MySQLDaoFactory;

public class Client {

  public static void main(String[] args) {
    IDaoFactory factory = new MySQLDaoFactory();
    IUserDao userDao = factory.createUserDao();
    userDao.getUser("admin");

  }

}

工廠方法模式示例代碼

本文所述工廠方法模式示例代碼可從作者Github下載

工廠方法模式優(yōu)點

  • 因為每個具體工廠類只負責創(chuàng)建產(chǎn)品告嘲,沒有簡單工廠中的邏輯判斷错维,因此符合單一職責原則。
  • 與簡單工廠模式不同橄唬,工廠方法并不使用靜態(tài)工廠方法赋焕,可以形成基于繼承的等級結(jié)構(gòu)。
  • 新增一種產(chǎn)品時仰楚,只需要增加相應(yīng)的具體產(chǎn)品類和相應(yīng)的工廠子類即可隆判,相比于簡單工廠模式需要修改判斷邏輯而言,工廠方法模式更符合開-閉原則僧界。

工廠方法模式缺點

  • 添加新產(chǎn)品時侨嘀,除了增加新產(chǎn)品類外,還要提供與之對應(yīng)的具體工廠類捎泻,系統(tǒng)類的個數(shù)將成對增加飒炎,在一定程度上增加了系統(tǒng)的復(fù)雜度,有更多的類需要編譯和運行笆豁,會給系統(tǒng)帶來一些額外的開銷郎汪。
  • 雖然保證了工廠方法內(nèi)的對修改關(guān)閉,但對于使用工廠方法的類闯狱,如果要換用另外一種產(chǎn)品煞赢,仍然需要修改實例化的具體工廠。
  • 一個具體工廠只能創(chuàng)建一種具體產(chǎn)品

簡單工廠模式與OOP原則

已遵循的原則

  • 依賴倒置原則
  • 迪米特法則
  • 里氏替換原則
  • 接口隔離原則
  • 單一職責原則(每個工廠只負責創(chuàng)建自己的具體產(chǎn)品哄孤,沒有簡單工廠中的邏輯判斷)
  • 開閉原則(增加新的產(chǎn)品照筑,不像簡單工廠那樣需要修改已有的工廠,而只需增加相應(yīng)的具體工廠類)

未遵循的原則

  • 開閉原則(雖然工廠對修改關(guān)閉了瘦陈,但更換產(chǎn)品時凝危,客戶代碼還是需要修改)

Java設(shè)計模式系列

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蛾默,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子捉貌,更是在濱河造成了極大的恐慌支鸡,老刑警劉巖冬念,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異牧挣,居然都是意外死亡急前,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進店門瀑构,熙熙樓的掌柜王于貴愁眉苦臉地迎上來裆针,“玉大人,你說我怎么就攤上這事检碗【菘椋” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵折剃,是天一觀的道長另假。 經(jīng)常有香客問我,道長怕犁,這世上最難降的妖魔是什么边篮? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮奏甫,結(jié)果婚禮上戈轿,老公的妹妹穿的比我還像新娘。我一直安慰自己阵子,他們只是感情好思杯,可當我...
    茶點故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著挠进,像睡著了一般色乾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上领突,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天暖璧,我揣著相機與錄音,去河邊找鬼君旦。 笑死澎办,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的金砍。 我是一名探鬼主播局蚀,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼恕稠!你這毒婦竟也來了琅绅?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤谱俭,失蹤者是張志新(化名)和其女友劉穎奉件,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體昆著,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡县貌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了凑懂。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片煤痕。...
    茶點故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖接谨,靈堂內(nèi)的尸體忽然破棺而出摆碉,到底是詐尸還是另有隱情,我是刑警寧澤脓豪,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布巷帝,位于F島的核電站,受9級特大地震影響扫夜,放射性物質(zhì)發(fā)生泄漏楞泼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一笤闯、第九天 我趴在偏房一處隱蔽的房頂上張望堕阔。 院中可真熱鬧,春花似錦颗味、人聲如沸超陆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽时呀。三九已至,卻和暖如春捐韩,著一層夾襖步出監(jiān)牢的瞬間退唠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工荤胁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瞧预,地道東北人。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓仅政,卻偏偏與公主長得像垢油,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子圆丹,可洞房花燭夜當晚...
    茶點故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內(nèi)容