原型模式:
原型實(shí)例指定創(chuàng)建對(duì)象的種類(lèi),并且通過(guò)拷貝這些原型創(chuàng)建新的對(duì)象。
原型模式本質(zhì)就是克隆對(duì)象,所以在對(duì)象初始化操作比較復(fù)雜的情況下,很實(shí)用,能大大降低耗時(shí),提高性能,因?yàn)?ldquo;不用重新初始化對(duì)象,而是動(dòng)態(tài)地獲得對(duì)象運(yùn)行時(shí)的狀態(tài)”。
應(yīng)用特性:
需要大量的基于某個(gè)基礎(chǔ)原型進(jìn)行微量修改而得到新原型時(shí)使用。
結(jié)構(gòu)特性:
對(duì)象的復(fù)制機(jī)制,即淺復(fù)制和深復(fù)制。
例1:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
#!/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é)果:
1
2
3
4
5
6
7
8
9
|
name1 2 #因?yàn)閛bj2是淺復(fù)制,所以對(duì)象沒(méi)有被復(fù)制,導(dǎo)致新對(duì)象的修改影響了原來(lái)的就對(duì)象的值 name2 2 name3 3 #因?yàn)槭巧顝?fù)制,所以不會(huì)影響之前的舊對(duì)象 __main__.proto_type __main__.proto_type __main__.proto_type |
這里我們?cè)賮?lái)回顧一下Python編程基礎(chǔ)中關(guān)于淺拷貝和深拷貝的知識(shí)點(diǎn):
淺拷貝(Shallow Copy):
指對(duì)象的字段被拷貝,而字段引用的對(duì)象不會(huì)被拷貝,拷貝的對(duì)象和源對(duì)象只是名稱相同,但是他們共用一個(gè)實(shí)體。
深拷貝(deep copy):
對(duì)對(duì)象實(shí)例中字段引用的對(duì)象也進(jìn)行拷貝。
好了,基于以上,我們?cè)賮?lái)看一個(gè)例子:
例2:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
#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 #簡(jiǎn)歷 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( '大鳥(niǎo)' ) 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(); |