利用类装饰器自定制property实现延迟计算

复制代码
class LazyProperty:

    '''
    hello,我是非数据描述符(没有定义__set__,不然是大哥数据描述符了--!)
    '''

    def __init__(self, func):
        print('>>>>>>>>>>这是LazyProperty的初始化方法__init__')
        # print(func)
        # print(func.__name__)
        self.func = func

    def __get__(self, instance, owner):
        print('》》》》》》这是__get__方法')

        # 类调用时instance为None,这时返回CrazyProperty对象
        if instance is None:
            return self
        res = self.func(instance)
        # 把结果保存到实例属性字典,可以实现延迟计算。即函数不用来回多次调用,提高效率
        setattr(instance, self.func.__name__, res)
        return res


class Room:
    def __init__(self, name, width, height):
        self.name = name
        self.width = width
        self.height = height

    # 类也可以作为装饰器,而且还是一个描述符呢,有意思吧
    @LazyProperty  # area = LazyProperty(area) 函数属性area被CrazyProperty代理了
    def area(self):
        return self.width * self.height


r1 = Room('toilet', 1, 1)
print(r1.area)
print(r1.area)
print(r1.area)
print(r1.area)
复制代码

运行结果

>>>>>>>>>>这是LazyProperty的初始化方法__init__
》》》》》》这是__get__方法
1
1
1
1

由结果可以看出,__get__只运行了一次,结果保存到了实例的属性字典,后面的调用直接在实例属性字典里取值。

 

posted @   Jervey  阅读(171)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示