python描述符跨类共享值

时间:2009-12-16 16:03:50

标签: python descriptor

我正在使用的python描述符是在其所有者类的所有实例之间共享其值。如何让每个实例的描述符包含自己的内部值?

class Desc(object):
    def __init__(self, initval=None,name='val'):
        self.val = initval
        self.name = name

    def __get__(self,obj,objtype):
        return self.val

    def __set__(self,obj,val):
        self.val = val

    def __delete__(self,obj):
        pass


class MyClass(object):
    desc = Desc(10,'varx')

if __name__ == "__main__":
    c = MyClass()
    c.desc = 'max'
    d = MyClass()
    d.desc = 'sally'

    print(c.desc)
    print(d.desc)

输出为此,最后一次调用设置两个对象的值:

localhost $ python descriptor_testing.py 
sally
sally

1 个答案:

答案 0 :(得分:7)

只有一个描述符对象存储在类对象中,因此self始终是相同的。如果你想存储每个对象的数据并通过描述符访问它,你要么必须将数据存储在每个对象上(可能是更好的想法),要么存储在每个对象键入的一些数据结构中(我不喜欢这个想法)同样多。)

我会在实例对象上保存数据:

class Desc(object):
    default_value = 10
    def __init__(self, name):
        self.name = name

    def __get__(self,obj,objtype):
        return obj.__dict__.get(self.name, self.default_value)
        # alternatively the following; but won't work with shadowing:
        #return getattr(obj, self.name, self.default_value)

    def __set__(self,obj,val):
        obj.__dict__[self.name] = val
        # alternatively the following; but won't work with shadowing:
        #setattr(obj, self.name, val)

    def __delete__(self,obj):
        pass


class MyClass(object):
    desc = Desc('varx')

在这种情况下,数据将存储在obj的{​​{1}}''varx'条目中。由于数据描述符查找的工作原理,您可以使用描述符“隐藏”存储位置:

__dict__

在这种情况下,当您进行查找时:

class MyClass(object):
    varx = Desc('varx')

描述符对象被调用并且可以进行查找,但是当查找如下:

MyClass().varx

直接返回该值。因此,描述符能够将其数据存储在“隐藏”的位置,可以这么说。