設(shè)計模式中的原型模式在Python程序中的應(yīng)用示例
原型模式:
原型實例指定創(chuàng)建對象的種類,并且通過拷貝這些原型創(chuàng)建新的對象。
原型模式本質(zhì)就是克隆對象,所以在對象初始化操作比較復(fù)雜的情況下,很實用,能大大降低耗時,提高性能,因為“不用重新初始化對象,而是動態(tài)地獲得對象運行時的狀態(tài)”。
應(yīng)用特性:
需要大量的基于某個基礎(chǔ)原型進行微量修改而得到新原型時使用。
結(jié)構(gòu)特性:
對象的復(fù)制機制,即淺復(fù)制和深復(fù)制。
例1:
#!/usr/bin/env python #encoding: utf-8 from copy import copy, deepcopy class test_obj: def __init__(self, id): self.id = id class proto_type: def __init__(self, name, id): self.name = name self.obj = test_obj(id) def display(self): print self.name print self.obj.id def clone(self): return copy(self) def deep_clone(self): return deepcopy(self) if '__main__' == __name__: obj1 = proto_type('name1', 1) obj2 = obj1.clone() obj3 = obj1.deep_clone() obj2.name = 'name2' obj2.obj.id = 2 obj3.name = 'name3' obj3.obj.id = 3 obj1.display() obj2.display() obj3.display() print obj1.__class__ print obj2.__class__ print obj3.__class__
結(jié)果:
name1 2 #因為obj2是淺復(fù)制,所以對象沒有被復(fù)制,導(dǎo)致新對象的修改影響了原來的就對象的值 name2 2 name3 3 #因為是深復(fù)制,所以不會影響之前的舊對象 __main__.proto_type __main__.proto_type __main__.proto_type
這里我們再來回顧一下Python編程基礎(chǔ)中關(guān)于淺拷貝和深拷貝的知識點:
淺拷貝(Shallow Copy):
指對象的字段被拷貝,而字段引用的對象不會被拷貝,拷貝的對象和源對象只是名稱相同,但是他們共用一個實體。
深拷貝(deep copy):
對對象實例中字段引用的對象也進行拷貝。
好了,基于以上,我們再來看一個例子:
例2:
#encoding=utf-8 # #by panda #原型模式 import copy def printInfo(info): print unicode(info, 'utf-8').encode('gbk') #拷貝接口 class ICloneable: def shallowClone(self): return copy.copy(self) def deepClone(self): return copy.deepcopy(self) #工作經(jīng)歷 class WorkExperience(ICloneable): workData = "" company = "" pass #簡歷 class Resume(ICloneable): name = "" sex = '未知' age = 0 work = None def __init__(self, name, work = WorkExperience()): self.name = name self.work = work; def setPersonInfo(self, sex, age): self.sex = sex self.age = age def setWorkExperience(self, workData, company): self.work.workData = workData self.work.company = company def display(self): printInfo('%s, %s, %d' % (self.name,self.sex,self.age)) printInfo('%s, %s' % (self.work.workData, self.work.company)) def clientUI(): a = Resume('大鳥') a.setPersonInfo('男',29) a.setWorkExperience("1998-2000","XX公司") #淺拷貝 b = a.shallowClone() b.setWorkExperience("2000-2006","YY公司") #深拷貝 c = a.deepClone() c.setWorkExperience("2006-2009","ZZ公司") b.display() a.display() c.display() return if __name__ == '__main__': clientUI();
相關(guān)文章
Python機器學(xué)習(xí)算法之決策樹算法的實現(xiàn)與優(yōu)缺點
決策樹(Decision Tree)是一種基本的分類與回歸方法,這篇文章主要給大家介紹了關(guān)于Python機器學(xué)習(xí)算法之決策樹算法實現(xiàn)與優(yōu)缺點的相關(guān)資料,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05Python selenium實現(xiàn)斷言3種方法解析
這篇文章主要介紹了Python selenium實現(xiàn)斷言3種方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-09-09Python網(wǎng)絡(luò)請求模塊urllib與requests使用介紹
網(wǎng)絡(luò)爬蟲的第一步就是根據(jù)URL,獲取網(wǎng)頁的HTML信息。在Python3中,可以使用urllib和requests進行網(wǎng)頁數(shù)據(jù)獲取,這篇文章主要介紹了Python網(wǎng)絡(luò)請求模塊urllib與requests使用2022-10-10