基于this comment关于reify,
它的作用类似于@property,只是函数只被调用一次;在此之后,值被缓存为一个常规属性。这使您可以对对象创建惰性属性,这些对象应该是不可变的。
我有一个定制的具体化类:
class reify(object):
def __init__(self, wrapped):
self.wrapped = wrapped
def __get__(self, inst):
if inst is None:
return self
val = self.wrapped(inst)
setattr(inst, self.wrapped.__name__, val)
return val它的用途就像:
@reify
def user_details(self, user_id):
try:
# function that executes db query, returns dict
return user_details_from_id(self._dbconn, user_id)
except Exception as e:
pass显然,我们可以使用它只做name = self.user_details.get("name")。
这可以正常工作,但不确定这是缓存结果还是每次调用时执行查询,我如何确认?我的意思是这个实现是正确的吗?(没有DB控制台)
发布于 2021-06-07 14:30:42
像def user_details(self, user_id)这样的签名有太多的arg不能被@reify甚至@property所支持。应该是def user_details(self)。然后,reify装饰器将修改属性self.user_details,以在实例持续时间内返回相同的值。注意,它不是全局的,而是每个实例的,因为它使用self。要确认它是缓存,只需将print语句放在user_details函数中,以确认每个实例只调用一次。
https://stackoverflow.com/questions/67780893
复制相似问题