python设计模式之享元模式

本文介绍享元模式的设计理念,即如何通过复用内存中存在的对象来减少系统创建对象实例的性能开销,进而提升系统性能。文章还提供了一个利用Python实现的卡片类实例,展示享元模式的具体应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

python设计模式之享元模式

意图

  • 运用共享技术有效地支持大量细粒度的对象

特点

  • 享元模式的特点是,复用我们内存中已存在的对象,降低系统创建对象实例的性能消耗

逻辑图如下

  • 不适用享元模式
    这里写图片描述

  • 使用享元模式
    这里写图片描述

使用场景

  • 当我们发现某个类型的对象有大量的实例时,我们是否可以对这些实例进行分类,经过分类后,我们发现只有很少的类别的情况下
  • 我们发现通过使用享元模式后能够提高系统的性能和不会带来更多的复杂度时
  • 一般是给出本地内存资源节省的一个方案

例子

import weakref


class Card(object):
    """The object pool. Has builtin reference counting"""
    _CardPool = weakref.WeakValueDictionary()

    """Flyweight implementation. If the object exists in the
    pool just return it (instead of creating a new one)"""

    def __new__(cls, value, suit):
        obj = Card._CardPool.get(value + suit, None)
        if not obj:
            obj = object.__new__(cls)
            Card._CardPool[value + suit] = obj
            obj.value, obj.suit = value, suit
        return obj

    def __repr__(self):
        return "<Card: %s%s>" % (self.value, self.suit)


if __name__ == '__main__':
    c1 = Card('9', 'h')
    c2 = Card('9', 'h')
    print(c1, c2)
    print(c1 == c2)
    print(id(c1), id(c2))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值