設(shè)計(jì)模式原則 - 開(kāi)閉原則(Open Closed Principle夷都,OCP)

個(gè)人理解 间螟,隨手寫(xiě)下的筆記。不足之處损肛,請(qǐng)諒解。

定義

(1)對(duì)于擴(kuò)展是開(kāi)放的(Open for extension)荣瑟。這意味著模塊的行為是可以擴(kuò)展的治拿。當(dāng)應(yīng)用的需求改變時(shí),我們可以對(duì)模塊進(jìn)行擴(kuò)展笆焰,使其具有滿(mǎn)足那些改變的新行為劫谅。也就是說(shuō),我們可以改變模塊的功能嚷掠。
(2)對(duì)于修改是關(guān)閉的(Closed for modification)捏检。對(duì)模塊行為進(jìn)行擴(kuò)展時(shí),不必改動(dòng)模塊的源代碼或者二進(jìn)制代碼不皆。模塊的二進(jìn)制可執(zhí)行版本贯城,無(wú)論是可鏈接的庫(kù)、DLL或者.EXE文件霹娄,都無(wú)需改動(dòng)能犯。

問(wèn)題

任何軟件都需要面臨一個(gè)很重要的問(wèn)題,即它們的需求會(huì)隨時(shí)間的推移而發(fā)生變化犬耻。當(dāng)軟件系統(tǒng)需要面對(duì)新的需求時(shí)踩晶,我們應(yīng)該盡量保證系統(tǒng)的設(shè)計(jì)框架是穩(wěn)定的。如果一個(gè)軟件設(shè)計(jì)符合開(kāi)閉原則枕磁,那么可以非常方便地對(duì)系統(tǒng)進(jìn)行擴(kuò)展渡蜻,而且在擴(kuò)展時(shí)無(wú)須修改現(xiàn)有代碼,使得軟件系統(tǒng)在擁有適應(yīng)性和靈活性的同時(shí)具備較好的穩(wěn)定性和延續(xù)性。隨著軟件規(guī)模越來(lái)越大茸苇,軟件壽命越來(lái)越長(zhǎng)排苍,軟件維護(hù)成本越來(lái)越高,設(shè)計(jì)滿(mǎn)足開(kāi)閉原則的軟件系統(tǒng)也變得越來(lái)越重要税弃。

解決方式

為系統(tǒng)定義一個(gè)相對(duì)穩(wěn)定的抽象層纪岁,而將不同的實(shí)現(xiàn)行為移至具體的實(shí)現(xiàn)層中完成。在很多面向?qū)ο缶幊陶Z(yǔ)言中都提供了接口则果、抽象類(lèi)等機(jī)制幔翰,可以通過(guò)它們定義系統(tǒng)的抽象層,再通過(guò)具體類(lèi)來(lái)進(jìn)行擴(kuò)展西壮。如果需要修改系統(tǒng)的行為遗增,無(wú)須對(duì)抽象層進(jìn)行任何改動(dòng),只需要增加新的具體類(lèi)來(lái)實(shí)現(xiàn)新的業(yè)務(wù)功能即可款青,實(shí)現(xiàn)在不修改已有代碼的基礎(chǔ)上擴(kuò)展系統(tǒng)的功能做修,達(dá)到開(kāi)閉原則的要求。

Java例子

/**
 * 抽象類(lèi)圖標(biāo)
 */
public abstract class AbsChat {
    public void display() {
        System.out.println("AbsChat");
    }
}
/**
 * 柱狀圖
 */
public class BarChat extends AbsChat {
    @Override
    public void display() {
        System.out.println("BarChat");
    }
}
/**
 * 餅圖
 */
public class PieChat extends AbsChat {
    @Override
    public void display() {
        System.out.println("PieChat");
    }
}
/**
 * 系統(tǒng)調(diào)用圖型顯示
 */
public class ChatDisplay {
    private AbsChat chat = null;
    public ChatDisplay(AbsChat chat) {
        this.chat = chat;
    }
    public void setChat(AbsChat chat) {
        this.chat = chat;
    }
    public void display() {
        chat.display();
    }
}
/**
 * 系統(tǒng)調(diào)用相應(yīng)的圖型顯示
 */
public class TestDemo {
    public static void main(String[] args) {
        //修改系統(tǒng)代碼的時(shí)候替換BarChat就好了抡草,如果使用Spring框架替換Bean配置就好了饰及,不用修改代碼,直接添加代碼就好了
        AbsChat chat = new BarChat();
//        AbsChat chat = new PieChat();
        ChatDisplay chatDisplay = new ChatDisplay(chat);
        chatDisplay.display();
    }
}

參考

百度百科:開(kāi)閉原則
面向?qū)ο笤O(shè)計(jì)原則之開(kāi)閉原則
設(shè)計(jì)模式六大原則(6):開(kāi)閉原則

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末康震,一起剝皮案震驚了整個(gè)濱河市燎含,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌腿短,老刑警劉巖屏箍,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異橘忱,居然都是意外死亡赴魁,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)钝诚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)颖御,“玉大人,你說(shuō)我怎么就攤上這事凝颇±杉蓿” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵祈噪,是天一觀(guān)的道長(zhǎng)泽铛。 經(jīng)常有香客問(wèn)我,道長(zhǎng)辑鲤,這世上最難降的妖魔是什么盔腔? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上弛随,老公的妹妹穿的比我還像新娘瓢喉。我一直安慰自己,他們只是感情好舀透,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布栓票。 她就那樣靜靜地躺著,像睡著了一般愕够。 火紅的嫁衣襯著肌膚如雪走贪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,692評(píng)論 1 305
  • 那天惑芭,我揣著相機(jī)與錄音坠狡,去河邊找鬼。 笑死遂跟,一個(gè)胖子當(dāng)著我的面吹牛逃沿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播幻锁,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼凯亮,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了哄尔?” 一聲冷哼從身側(cè)響起假消,我...
    開(kāi)封第一講書(shū)人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎究飞,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體堂鲤,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡亿傅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瘟栖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片葵擎。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖半哟,靈堂內(nèi)的尸體忽然破棺而出酬滤,到底是詐尸還是另有隱情,我是刑警寧澤寓涨,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布盯串,位于F島的核電站,受9級(jí)特大地震影響戒良,放射性物質(zhì)發(fā)生泄漏体捏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望几缭。 院中可真熱鬧河泳,春花似錦、人聲如沸年栓。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)某抓。三九已至纸兔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間搪缨,已是汗流浹背食拜。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留副编,地道東北人负甸。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像痹届,于是被迫代替她去往敵國(guó)和親呻待。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

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

  • 設(shè)計(jì)模式之六大原則(轉(zhuǎn)載) 關(guān)于設(shè)計(jì)模式的六大設(shè)計(jì)原則的資料網(wǎng)上很多...
    霄霄霄霄閱讀 899評(píng)論 0 1
  • 轉(zhuǎn)載標(biāo)注聲明:http://www.uml.org.cn/sjms/201211023.asp 目錄:[設(shè)計(jì)模式六...
    Bloo_m閱讀 717評(píng)論 0 7
  • 前言 設(shè)計(jì)模式六大原則網(wǎng)上資料比較多比較亂队腐,本文將網(wǎng)上的一些好的資料做一下整理蚕捉,以便隨時(shí)翻閱。友情提示柴淘,設(shè)計(jì)模式雖...
    簡(jiǎn)單的土豆閱讀 1,435評(píng)論 0 10
  • 設(shè)計(jì)模式六大原則 設(shè)計(jì)模式六大原則(1):?jiǎn)我宦氊?zé)原則 定義:不要存在多于一個(gè)導(dǎo)致類(lèi)變更的原因迫淹。通俗的說(shuō),即一個(gè)類(lèi)...
    viva158閱讀 768評(píng)論 0 1
  • 設(shè)計(jì)模式六大原則(1):?jiǎn)我宦氊?zé)原則 定義:不要存在多于一個(gè)導(dǎo)致類(lèi)變更的原因为严。通俗的說(shuō)敛熬,即一個(gè)類(lèi)只負(fù)責(zé)一項(xiàng)職責(zé)。 ...
    Jabir_Zhang閱讀 646評(píng)論 0 3