2

Python 2.6 中的描述符协议仅为类定义而定义,因此只能由实例使用。

是否有一些等效的仪器获取/设置全局变量?

我正在尝试加快与主机系统交互的模块的导入,因此必须对主机进行一些昂贵的探测。(昂贵的)探测的结果存储在导入时初始化的模块全局中;所以我试图将初始化延迟到绝对需要为止。

请不要评论全局变量是邪恶的。我知道它们是什么以及何时使用它们。

我目前的计划是创建一个使用描述符的全局实例,并将我当前的所有全局变量移动到该实例的属性中。我希望这会奏效;我只是问有没有其他方法。

4

2 回答 2

2

我目前的计划是创建一个使用描述符的全局实例,并将我当前的所有全局变量移动到该实例的属性中。我希望这会奏效;我只是问有没有其他方法。

这正是我会做的。类之外没有等价的描述符。

我有时也使用的另一个选项是使用函数而不是变量名,如下所示:

_expensive_to_compute = None
def get_expensive_to_compute():
    global _expensive_to_compute
    if _expensive_to_compute is None:
        _expensive_to_compute = do_computation()
    return _expensive_to_compute

如果您已经在@memoize某处定义了装饰器,则可以大大简化上述内容。

于 2010-08-23T16:48:13.733 回答
1

如果你真的想这样做,这个链接提供了一个非常酷的实现方法。唯一需要注意的是你必须使用 eval/exec/execfile 来执行你的代码。

https://mail.python.org/pipermail/python-ideas/2011-March/009657.html

class MyDict:
    def __init__(self, mapping):
        self.mapping = mapping
    def __getitem__(self, key):
        value = self.mapping[key]
        if hasattr(value, '__get__'):
            print('Invoking descriptor on', key)
            return value.__get__(key)
        print('Getting', key)
        return value
    def __setitem__(self, key, value):
        self.mapping[key] = value

class Property:
    def __init__(self, getter):
        self.getter = getter
    def __get__(self, key):
        return self.getter(key)

if __name__ == '__main__':   
    md = MyDict({})
    md['x'] = 10
    md['_y'] = 20
    md['y'] = Property(lambda key: md['_'+key])
    print(eval('x+y+1', {}, md))

虽然有点麻烦,但我觉得这很酷。

于 2014-07-01T01:51:56.293 回答