通过描述符实现懒加载
2023-04-12 本文已影响0人
高峥
class lazy(object):
def __init__(self, func):
self.func = func #lazy的实例属性func等于area方法对象
def __get__(self, instance, cls):
val = self.func(instance) #调用area方法计算出结果
setattr(instance, self.func.__name__, val) #将结果设置给c的area属性
return val
class Circle(object):
def __init__(self, radius):
self.radius = radius
@ lazy #area = lazy(area) lazy描述符
def area(self):
print 'evalute'
return 3.14 * self.radius ** 2
c = Circle(4)
print c.radius
print c.area
print c.area
print c.area
结果'evalute'只输出了一次。在lazy类中,我们定义了get()方法,所以它是一个描述符。当我们第一次执行c.area时,python解释器会先从c.dict中进行查找,没有找到,就从Circle.dict中进行查找,这时因为area被定义为描述符,所以调用get方法。
在get()方法中,调用实例的area()方法计算出结果,并动态给实例添加一个同名属性area,然后将计算出的值赋予给它,相当于设置c.dict['area']=val。
当我们再次调用c.area时,直接从c.dict中进行查找,这时就会直接返回之前计算好的值了。
原文链接:https://blog.csdn.net/azsx02/article/details/77649527