设计模式---延迟初始化Lazy initialization

参考https://devakimbo.com/lazy-initialization-design-pattern-python-for-web-developers/

在实例化一个class的时候,并不直接生成其对象,而是等需要的时候,才进行里边参数的初始化,这样做可以节省带宽资源、数据库资源、RAM、CPU

举个例子

假设我们现在要做一个在线购物网站,有一个对象叫做Customer,每一个Customer对象都有一个订单列表(很长),如果没有使用Lazy loading技术,那么每当我们想要创建Customer对象的时候,我们都会从数据库里读取该对象的整个订单列表。

再考虑一种更糟糕的情况,如果我们想要获取Customer的一个list,那么就需要去数据库查询出所有Customer

为了解决这个问题,我们可以像下边这样实现Customer

class Customer:
    def __init__(self):
        self._orders = None

    def get_orders(self):
        if self._orders is None:
            self._orders = self._load_orders()
        return self._orders

    def _load_orders(self):
        print("loading orders")
        return []

customer = Customer()

customer.get_orders()
customer.get_orders()
customer.get_orders()
customer.get_orders()
customer.get_orders()

这段程序的输出是

loading orders

在我们的Customer类里边,我们通过调用get_orders方法获取获取一个Customer订单的列表,但是在我们进行Customer初始化__init__方法的时候,self._orders = None,说明并没有将用户订单进行加载(注意这里使用了None,而不是一个空的list,如果我们使用了空的list,就相当于该用户没有订单

当调用get_orders()方法的时候,我们最开始的self._orders == None,因此Customer对象会调用_load_orders()方法,加载该用户的订单(print和return)

之后,若再次调用Customerget_orders()方法,我们会发现此时self._orders != None,因此可以直接return self._orders,而没有重新调用订单加载的部分(print和return),因此整个虽然我们多次调用了customer.get_orders(),但是却只进行了一次订单的查询,且仅当第一次调用get_orders()方法的时候才进行了订单的查询,这样就避免了网络资源、数据库资源、CPU资源等的浪费。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值