所谓类属性的延迟计算就是将类的属性定义成一个property,只在访问的时候才会计算,而且一旦被访问后,结果将会被缓存起来,不用每次都计算。
优点
构造一个延迟计算属性的主要目的是为了提升性能
实现
class LazyProperty(object): def __init__(self, func): self.func = func def __get__(self, instance, owner): if instance is None: return self else: value = self.func(instance) setattr(instance, self.func.__name__, value) return value import math class Circle(object): def __init__(self, radius): self.radius = radius @LazyProperty def area(self): print 'Computing area' return math.pi * self.radius ** 2 @LazyProperty def perimeter(self): print 'Computing perimeter' return 2 * math.pi * self.radius
说明
定义了一个延迟计算的装饰器类LazyProperty。Circle是用于测试的类,Circle类有是三个属性半径(radius)、面积(area)、周长(perimeter)。面积和周长的属性被LazyProperty装饰,下面来试试LazyProperty的魔法:
>>> c = Circle(2) >>> print c.area Computing area 12.5663706144 >>> print c.area 12.5663706144
在area()中每计算一次就会打印一次“Computing area”,而连续调用两次c.area后“Computing area”只被打印了一次。这得益于LazyProperty,只要调用一次后,无论后续调用多少次都不会重复计算。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
问题内容: foo类有一个酒吧。除非访问,否则不会加载钢筋。进一步访问bar应该不会产生任何开销。 是否可以使用属性或更好的属性来执行类似的操作,而不是使用getter方法? 目标是在所有后续访问中无负载地延迟加载… 问题答案: 当前的答案存在一些问题。具有属性的解决方案要求您指定其他类属性,并且在每次查找时都要检查该属性。该解决方案的问题在于,它会隐藏该属性,直到首次访问。这不利于自省,并且不便
问题 你想将一个只读属性定义成一个property,并且只在访问的时候才会计算结果。 但是一旦被访问后,你希望结果值被缓存起来,不用每次都去计算。 解决方案 定义一个延迟属性的一种高效方法是通过使用一个描述器类,如下所示: class lazyproperty: def __init__(self, func): self.func = func def __ge
问题内容: 请考虑以下示例: Web应用程序为每个登录用户创建一个用户对象。该对象具有的简单属性,… 每个用户也可以拥有一个。考虑到获取用户非常昂贵,因此我们不希望在用户登录时不设置用户汽车。相反,我们希望在用例需要时获得汽车。 为了实现这一点,我们创建了一个用户pojo: 登录后的初始用户: 每个需要用车的用例都可以轻松获得: 但是,我一直认为通过这种方式,我的User对象不再是简单的pojo了
问题内容: 我正在尝试把我的头围住Swift语言。使用Objective-C在代码中构建视图时,常见的模式是覆盖UI属性并像这样延迟加载它们: 这允许将UIElement的配置包含在其设置中,但是不会导致每次都对其进行重新配置。 看来我们无权访问Swift中的后备存储,并且关键字实际上没有相同的语义。 我很好奇是否有人在Swift中找到了类似的模式,该模式允许人们以一种简洁的语法方式将变量和常量的
问题内容: 我有一个正在使用的旧桌子,看起来像这样: 这样做的主要问题是,即使我只需要使用Java类也可以加载列。我知道,构造此文件的最佳方法是从元数据中拆分数据(例如文件名),以便它们位于单独的表中。从那里开始,使数据延迟加载很简单。这就是应该首先完成的方式。 不幸的是,由于组织限制,我可能无法执行上述操作。作为一种解决方法,是否可以使用某些注释将列延迟加载,而不是将其拆分为单独的表?我已经修改
是否有可能拥有一个java。util。可选,仅在需要时才进行评估? 我需要将一个传递给一个方法(我无法更改的API),并且这个方法可能会也可能不会使用该的值。由于该值是由一个繁重的操作计算的,因此我想仅在需要时(如果需要)计算该值,例如调用、、等。 类似