Python設(shè)計(jì)模式 - 工廠模式

簡(jiǎn)單工廠模式

歡迎關(guān)注我的公眾號(hào):zx94_11
基于一個(gè)包含do_say()方法的Animal的抽象類創(chuàng)建兩個(gè)類

  • Cat
  • Dog
from abc import ABCMeta, abstractmethod

class Animal(metaclass=ABCMeta):
    @abstractmethod
    def do_say(self):
        pass


class Dog(Animal):
    def do_say(self):
        print("Bhow Bhow!!")


class Cat(Animal):
    def do_say(self):
        print("Meow Meow!!")

創(chuàng)建一個(gè)包含make_sound()方法的工廠類ForestFactory

class ForestFactory(object):
    def make_sound(self, object_type):
        return eval(object_type)().do_say()

制造點(diǎn)聲音

if __name__ == '__main__':
    ff = ForestFactory()
    animal = input("Which animal should make_sound?[Dog or Cat]")
    ff.make_sound(animal)
運(yùn)行結(jié)果

類關(guān)系圖

類關(guān)系圖

工廠方法模式

有兩個(gè)社交網(wǎng)站LinkedIn和Facebook历葛,它們的個(gè)人簡(jiǎn)介界面有各自不同的內(nèi)容

內(nèi)容抽象類Section

from abc import ABCMeta, abstractmethod


class Section(metaclass=ABCMeta):
    @abstractmethod
    def describe(self):
        pass

不同的內(nèi)容

  • PersonalSection
  • AlbumSection
  • PatenSection
  • PublicationSection
class PersonalSection(Section):
    def describe(self):
        print("Personal Section")


class AlbumSection(Section):
    def describe(self):
        print("Album Section")


class PatenSection(Section):
    def describe(self):
        print("Patent Section")


class PublicationSection(Section):
    def describe(self):
        print("Publication Section")

公司抽象類Profile

class Profile(metaclass=ABCMeta):
    def __init__(self):
        self.sections = []
        self.createProfile()

    @abstractmethod
    def createProfile(self):
        pass

    def getSections(self):
        return self.sections

    def addSections(self, section):
        self.sections.append(section)

公司類

  • linkedin
  • facebook
class linkedin(Profile):
    def createProfile(self):
        self.addSections(PersonalSection())
        self.addSections(PatenSection())
        self.addSections(PublicationSection())


class facebook(Profile):
    def createProfile(self):
        self.addSections(PersonalSection())
        self.addSections(AlbumSection())

選擇一個(gè)社交網(wǎng)站

if __name__ == '__main__':
    profile_type = input("Which Profile you`d like to create?[LinkedIn or FaceBook]")
    profile = eval(profile_type.lower())()
    print("Creating Profile..", type(profile).__name__)
    print("Profile has sections --", profile.getSections())
測(cè)試結(jié)果

類關(guān)系圖

工廠方法模式

抽象工廠模式

一家提供印式和美式披薩的店(抽象類PizzFactory

class PizzFactory(metaclass=ABCMeta):
    @abstractmethod
    def createVegPizza(self):
        pass

    @abstractmethod
    def createNonVegPizza(self):
        pass
  • IndianPizzaFactory
  • USPizzaFactory
class IndianPizzaFactory(PizzFactory):
    def createVegPizza(self):
        return DeluxVeggiePizza()

    def createNonVegPizza(self):
        return ChickenPizza()


class USPizzaFactory(PizzFactory):
    def createVegPizza(self):
        return MexicanVegPizza()

    def createNonVegPizza(self):
        return HamPizza()

兩種不同的披薩(抽象類)

  • 素食披薩NonVegPizza
  • 非素食披薩VegPizza
class VegPizza(metaclass=ABCMeta):
    @abstractmethod
    def prepare(self):
        pass


class NonVegPizza(metaclass=ABCMeta):
    @abstractmethod
    def serve(self, VegPizza):
        pass

四種不同的披薩

  • DeluxVeggiePizza
  • ChickenPizza
  • MexicanVegPizza
  • HamPizza
class DeluxVeggiePizza(VegPizza):
    def prepare(self):
        print("Prepare ", type(self).__name__)


class ChickenPizza(NonVegPizza):
    def serve(self, VegPizza):
        print(type(self).__name__, " is served with Chicken on", type(VegPizza).__name__)


class MexicanVegPizza(VegPizza):
    def prepare(self):
        print("Prepare ", type(self).__name__)


class HamPizza(NonVegPizza):
    def serve(self, VegPizza):
        print(type(self).__name__, " is served with Ham on", type(VegPizza).__name__)

到此就完成了一家披薩店肢预,有兩個(gè)國(guó)家口味,各有葷素的披薩。

整合為一個(gè)制造披薩的工廠

class PizzaStore:
    def __init__(self):
        pass

    def makePizzas(self):
        for factory in [IndianPizzaFactory(), USPizzaFactory()]:
            self.factory = factory
            self.NonVegPizza = self.factory.createNonVegPizza()
            self.VegPizza = self.factory.createVegPizza()
            self.VegPizza.prepare()
            self.NonVegPizza.serve(self.VegPizza)

測(cè)試

if __name__ == '__main__':
    pizza = PizzaStore()
    pizza.makePizzas()
測(cè)試結(jié)果

類關(guān)系圖

類關(guān)系圖

工廠方法和抽象工廠方法

工廠方法 抽象工廠方法
向客戶端開發(fā)了一個(gè)創(chuàng)建對(duì)象的方法 包含一個(gè)或多個(gè)工廠方法來創(chuàng)建一個(gè)系列的相關(guān)對(duì)象
使用繼承和子類來決定要?jiǎng)?chuàng)建哪個(gè)對(duì)象 使用組合將創(chuàng)建對(duì)象的任務(wù)委托給其他類
用于創(chuàng)建一個(gè)產(chǎn)品 用于創(chuàng)建相關(guān)產(chǎn)品的系列
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末稠集,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子捆愁,更是在濱河造成了極大的恐慌燕刻,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件隅俘,死亡現(xiàn)場(chǎng)離奇詭異邻奠,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)为居,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門碌宴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蒙畴,你說我怎么就攤上這事贰镣。” “怎么了膳凝?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵碑隆,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我蹬音,道長(zhǎng)上煤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任著淆,我火速辦了婚禮劫狠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘永部。我一直安慰自己独泞,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布苔埋。 她就那樣靜靜地躺著懦砂,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上荞膘,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天罚随,我揣著相機(jī)與錄音,去河邊找鬼衫画。 笑死毫炉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的削罩。 我是一名探鬼主播瞄勾,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼弥激!你這毒婦竟也來了进陡?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤微服,失蹤者是張志新(化名)和其女友劉穎趾疚,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體以蕴,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡糙麦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了丛肮。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赡磅。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖宝与,靈堂內(nèi)的尸體忽然破棺而出焚廊,到底是詐尸還是另有隱情,我是刑警寧澤习劫,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布咆瘟,位于F島的核電站,受9級(jí)特大地震影響诽里,放射性物質(zhì)發(fā)生泄漏袒餐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一谤狡、第九天 我趴在偏房一處隱蔽的房頂上張望灸眼。 院中可真熱鬧,春花似錦豌汇、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春逻澳,著一層夾襖步出監(jiān)牢的瞬間闸天,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工斜做, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留苞氮,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓瓤逼,卻偏偏與公主長(zhǎng)得像笼吟,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子霸旗,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

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

  • 除了使用new操作符之外贷帮,還有更多制造對(duì)象的方法。你講了解到實(shí)例化這個(gè)活動(dòng)不應(yīng)該總是公開的進(jìn)行诱告,也會(huì)認(rèn)識(shí)到初始化經(jīng)...
    pilipalaKing閱讀 371評(píng)論 0 0
  • 該文章屬于劉小壯原創(chuàng)撵枢,轉(zhuǎn)載請(qǐng)注明:劉小壯[http://www.reibang.com/u/2de707c93d...
    劉小壯閱讀 12,763評(píng)論 29 59
  • 前言 關(guān)于設(shè)計(jì)模式,是一個(gè)永遠(yuǎn)說不完的也說不清的話題精居。畢竟在編程的世界里锄禽,沒有最好的設(shè)計(jì)模式,只有最合適的設(shè)計(jì)模式...
    VV木公子閱讀 1,491評(píng)論 0 9
  • 棚戶區(qū)改造是城市更新發(fā)展當(dāng)中出現(xiàn)的必須要解決的問題靴姿。隨著城市化進(jìn)程的不斷加快沃但,如何把棚戶區(qū)改造做好做細(xì),為城市化做...
    晴明荔枝閱讀 522評(píng)論 0 0
  • 晨起霧大,下午才見陽光辈毯。 燒晚飯時(shí)燙傷了手指坝疼,好大一片。緊急處理后還是疼痛難忍谆沃。娃說吹吹吧钝凶,就賣力吹。我說不要吹了...
    云淡風(fēng)清澈閱讀 585評(píng)論 0 48