欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

設(shè)計模式中的原型模式在Python程序中的應(yīng)用示例

 更新時間:2016年03月02日 11:13:00   作者:像風(fēng)一樣的自由  
這篇文章主要介紹了設(shè)計模式中的原型模式在Python程序中的應(yīng)用示例,文中主要強調(diào)了對淺拷貝和深拷貝在對象復(fù)制時的使用,需要的朋友可以參考下

原型模式:
原型實例指定創(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使用cookielib庫示例分享

    python使用cookielib庫示例分享

    Python中cookielib庫(python3中為http.cookiejar)為存儲和管理cookie提供客戶端支持,下面是使用示例
    2014-03-03
  • Python機器學(xué)習(xí)算法之決策樹算法的實現(xiàn)與優(yōu)缺點

    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-05
  • Python批量操作Excel文件詳解

    Python批量操作Excel文件詳解

    因為博主所在的地方,需要每周整理全校的青年大學(xué)習(xí)數(shù)據(jù),Excel操作本身不難,但是這種毫無意義的體力勞動做久了就會很無趣,剛好我想起來上學(xué)期接觸過Python,想著能不能試一下,取代這種無意義的勞動
    2021-11-11
  • python排序算法之歸并排序

    python排序算法之歸并排序

    這篇文章主要介紹了python排序算法之歸并排序,歸并排序算法就是一個先把數(shù)列拆分為子數(shù)列,對子數(shù)列進行排序后,再把有序的子數(shù)列合并為完整的有序數(shù)列的算法,需要的朋友可以參考下
    2023-04-04
  • python使用正則表達式匹配反斜杠\遇到的問題

    python使用正則表達式匹配反斜杠\遇到的問題

    在學(xué)習(xí)Python正則式的過程中,有一個問題一直困擾我,如何去匹配一個反斜杠(即“\”),下面這篇文章主要給大家介紹了關(guān)于python使用正則表達式匹配反斜杠\的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • Python selenium實現(xiàn)斷言3種方法解析

    Python selenium實現(xiàn)斷言3種方法解析

    這篇文章主要介紹了Python selenium實現(xiàn)斷言3種方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • python識別圖像并提取文字的實現(xiàn)方法

    python識別圖像并提取文字的實現(xiàn)方法

    這篇文章主要介紹了python識別圖像并提取文字的實現(xiàn)方法,
    2019-06-06
  • Python網(wǎng)絡(luò)請求模塊urllib與requests使用介紹

    Python網(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
  • 分享10提高?Python?代碼的可讀性的技巧

    分享10提高?Python?代碼的可讀性的技巧

    這篇文章主要介紹了分享10提高?Python?代碼的可讀性的技巧,本文介紹20個常用的Python技巧來提高代碼的可讀性,并能幫助你節(jié)省大量時間,下面的技巧將在你的日常編碼練習(xí)中非常實用,需要的朋友可以參考一下
    2022-03-03
  • Python進行Restful?API開發(fā)實例詳解

    Python進行Restful?API開發(fā)實例詳解

    這篇文章主要介紹了Python進行Restful?API開發(fā)實例,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03

最新評論