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