Python 设计模式—原型模式

前期分享过几篇关于设计模式的文章,今天继续分享设计模式——原型模式

我们将会使用原型实例指定创建对象的种类,并且通过深拷贝这些原型创建新的对象。

原型模式本质就是克隆对象,所以在对象初始化操作比较复杂的情况下,很实用,能大大降低耗时,提高性能。

在原型模式下我们不用重新初始化对象,而是动态地获得对象运行时的状态。

深浅拷贝的含义

浅拷贝(Shallow Copy):指对象的字段被拷贝,而字段引用的对象不会被拷贝,拷贝的对象和源对象只是名称相同,但是他们共用一个实体。
浅拷贝会拷贝对象内容及其内容的引用或者子对象的引用,但不会拷贝引用的内容和子对象本身。

深拷贝(deep copy):对对象实例中字段引用的对象也进行拷贝。深拷贝不仅拷贝了对象和内容的引用,也会拷贝引用的内容。所以,一般深拷贝比浅拷贝复制得更加完全,但也更占资源(包括时间和空间资源)。

使用场景

当我们有一个迭代项目要更新时,第二个版本中的对象实例要在第一个版本的基础上做一些修改时,这个时候我们就可以使用原型模式来实现,从而大大节省了时间,提高了效率。

优点

原型模式用于创建复杂的或者耗时的实例:复制一个已经存在的实例使程序运行更高效。且对于工厂模式,原型模式减少了子类的构建。

缺点

每一个产品类都必须配置一个克隆方法,并且这个克隆方法需要对类的功能进行整体考虑。

Python 代码实现

import copy
from collections import OrderedDict
 
#定义一个人的类
class Person():
    def __init__(self,name,age,high,sex,**info):
        self.name=name
        self.age=age
        self.high=high
        self.sex=sex
        #可以为实例添加其他额外属性,但必须是key:value格式的属性
        self.__dict__.update(info)
 
    #当使用print输出对象的时候,只要自己定义了__str__(self)方法,那么就会打印从在这个方法中return的数据
    def __str__(self):
        myinfo=[]
        #OrderedDict 是 collections 提供的一种数据结构, 它提供了有序的dict结构。
        order_dict=OrderedDict(self.__dict__.items())
        for i in order_dict.keys():
            myinfo.append('{}:{}'.format(i,order_dict[i]))
            myinfo.append('
')
        return ''.join(myinfo)

定义一个原型的类

class Prototype():
    def __init__(self):
        self.objects=dict() #定义原型对象字典表
 
    #在原型字典表中注册原型对象
    def register(self,id,obj):
        self.objects[id]=obj
 
    #在原型字典表中删除原型对象
    def destory(self,id):
        del self.objects[id]
 
    #根据 id 在原型字典表中查找原型对象并克隆
    def clone(self,id,**atter):
        obj1=self.objects.get(id)
        print(obj1)
        if not obj1:
            raise ValueError('Incorrect object id: {}'.format(id))
        obj2=copy.deepcopy(obj1)
        obj2.__dict__.update(atter)
        return obj2
 
 
if __name__ == '__main__':
    tony=Person('tony',34,170,'man',job='tester',birthday='2000-01-01',hobby='catch fish')
    print(tony)
 
    prototype=Prototype()
    prototype.register(1001,tony)
    tom=prototype.clone(1001,name='tom',age='19',birthday='2010-02-02')
 
    for i in (tony,tom):
        print(i)
    #输出两个Person对象是否是相同的id值
    print("id tony : {} != id tom : {}".format(id(tony), id(tom)))

输出的内容如下所示

name:tony
age:34
high:170
sex:man
job:tester
birthday:2000-01-01
hobby:catch fish
 
name:tony
age:34
high:170
sex:man
job:tester
birthday:2000-01-01
hobby:catch fish
 
name:tony
age:34
high:170
sex:man
job:tester
birthday:2000-01-01
hobby:catch fish
 
name:tom
age:19
high:170
sex:man
job:tester
birthday:2010-02-02
hobby:catch fish
 
id tony : 2930225522448 != id tom : 2930225522504

欢迎关注【无量测试之道】公众号,回复【领取资源】
Python编程学习资源干货、
Python+Appium框架APP的UI自动化、
Python+Selenium框架Web的UI自动化、
Python+Unittest框架API自动化、

资源和代码 免费送啦~
文章下方有公众号二维码,可直接微信扫一扫关注即可。

备注:我的个人公众号已正式开通,致力于测试技术的分享,包含:大数据测试、功能测试,测试开发,API接口自动化、测试运维、UI自动化测试等,微信搜索公众号:“无量测试之道”,或扫描下方二维码:

 

 添加关注,让我们一起共同成长!

原文地址:https://www.cnblogs.com/Wu13241454771/p/14593444.html