設計模式-結構型模式,python組合模式

設計模式上大的方向上分繼承和組合,就是類模式和對象模式。此篇的組合模式非繼承和組合概念中的組合。橋接 策略 代理 裝飾者都用了組合,此組合非彼組合。

 

組合模式

組合模式(Composite Pattern),又叫部分總體模式,是用於把一組類似的對象看成一個單一的對象。組合模式依據樹形結構來組合對象,用來表示部分以及總體層次。這種類型的設計模式屬於結構型模式,它建立了對象組的樹形結構。設計模式

這種模式建立了一個包含本身對象組的類。該類提供了修改相同對象組的方式。app

咱們經過下面的實例來演示組合模式的用法。實例演示了一個組織中員工的層次結構。spa

介紹

意圖:將對象組合成樹形結構以表示"部分-總體"的層次結構。組合模式使得用戶對單個對象和組合對象的使用具備一致性。設計

主要解決:它在咱們樹型結構的問題中,模糊了簡單元素和複雜元素的概念,客戶程序能夠向處理簡單元素同樣來處理複雜元素,從而使得客戶程序與複雜元素的內部結構解耦。代理

什麼時候使用: 一、您想表示對象的部分-總體層次結構(樹形結構)。 二、您但願用戶忽略組合對象與單個對象的不一樣,用戶將統一地使用組合結構中的全部對象。code

如何解決:樹枝和葉子實現統一接口,樹枝內部組合該接口。component

關鍵代碼:樹枝內部組合該接口,而且含有內部屬性 List,裏面放 Component。對象

應用實例: 一、算術表達式包括操做數、操做符和另外一個操做數,其中,另外一個操做符也能夠是操做數、操做符和另外一個操做數。 二、在 JAVA AWT 和 SWING 中,對於 Button 和 Checkbox 是樹葉,Container 是樹枝。blog

優勢: 一、高層模塊調用簡單。 二、節點自由增長。繼承

缺點:在使用組合模式時,其葉子和樹枝的聲明都是實現類,而不是接口,違反了依賴倒置原則。

使用場景:部分、總體場景,如樹形菜單,文件、文件夾的管理。

注意事項:定義時爲具體類。

 

#Component:公司抽象類
class Company:
    name = ''
    def __init__(self, name):
        self.name = name
        
    def Add(self, company):
        pass 
    
    def Remove(self, company):
        pass 
    
    def Display(self, depth):
        pass 
 
    def LineOfDuty(self): #履行職責
        pass 
    
#Composite:公司類
class ConcreteCompany(Company):
    childrenCompany = None
    
    def __init__(self, name):
        Company.__init__(self,name)
        self.childrenCompany = []
        
    def Add(self, company):
        self.childrenCompany.append(company) 
    
    def Remove(self, company):
        self.childrenCompany.remove(company) 
    
    def Display(self, depth):
        printInfo('-'*depth + self.name)
        
        for component in self.childrenCompany:
            component.Display(depth+2)
        
 
    def LineOfDuty(self): #履行職責
        for component in self.childrenCompany:
            component.LineOfDuty()
        
#Leaf:具體職能部門
class HRDepartment(Company):   
    def __init__(self, name):
         Company.__init__(self,name)
     
    def Display(self, depth):
        printInfo('-'*depth + self.name)
    
    def LineOfDuty(self): #履行職責
        printInfo('%s\t員工招聘培訓管理' % self.name)
 
#Leaf:具體職能部門
class FinanceDepartment(Company):    
    def __init__(self, name):
        Company.__init__(self,name)
        
    def Display(self, depth):
        printInfo('-'*depth + self.name)
    
    def LineOfDuty(self): #履行職責
        printInfo('%s\t公司財務收支管理' % self.name)
 
def clientUI():    
    root = ConcreteCompany('北京總公司')
    root.Add(HRDepartment('總公司人力資源部'))
    root.Add(FinanceDepartment('總公司財務部'))
    
    comp = ConcreteCompany('華東分公司')
    comp.Add(HRDepartment('華東分公司人力資源部'))
    comp.Add(FinanceDepartment('華東分公司財務部'))
    root.Add(comp)
    
    comp1 = ConcreteCompany('南京辦事處')
    comp1.Add(HRDepartment('南京辦事處人力資源部'))
    comp1.Add(FinanceDepartment('南京辦事處財務部'))
    comp.Add(comp1)
    
    comp2 = ConcreteCompany('杭州辦事處')
    comp2.Add(HRDepartment('杭州辦事處人力資源部'))
    comp2.Add(FinanceDepartment('杭州辦事處財務部'))
    comp.Add(comp2)    
    
    printInfo('-------公司結構圖-------')
    root.Display(1)
    
    printInfo('\n-------職責-------')
    root.LineOfDuty()
    return
 
if __name__ == '__main__':
clientUI();

 

以上爲複製的,大概意思就是這樣的。一棵樹有不少樹枝,每一個樹枝有不少葉子。從樹獲得樹枝,就能獲得全部葉子了。

相關文章
相關標籤/搜索