python描述器的访问顺序如下
数据描述器 > 实例属性 > 非数据描述器;实例属性 > 类属性。
当存在描述器的时候,一个类实例的查找属性顺序为:先查找类或父类中是否有数据描述器属性,如果有那么,先访问数据描述器,如果没有数据描述器 –> 那么就会查找自己实例的dict属性,如果dict属性里面也没有找到 –> 然后会在类或父类的非数据描述器进行查找。
python描述器的访问实例
# 例子二 class A: def __init__(self): self.x = 1 def __get__(self, instance, owner): """ 以下两个参数都是「必须参数」,约定使用 instance: 描述器所在类的实例 owner:调用描述器的类 """ return self.x def __set__(self, instance, value): """ 以下两个参数都是「必须参数」,约定使用 instance: 描述器所在类的实例 value:用来设置属性的值 """ self.x = value def __delete__(self, instance): """ 以下参数是「必须参数」,约定使用 instance: 描述器所在类的实例 """ pass class B: def __init__(self): self.x = 1 def __get__(self, instance, owner): return self.x class C: a = A() b = B() def __init__(self, a, b): self.b = a self.b = b
上面在class C中,分别定义了资料描述器和非资料描述器a,b以及同名的实例属性,进行以下输出测试,发现实例c只存在实例属性b,不存在实例属性a,说明其确实是被资料描述器,即类属性a给屏蔽了。
以上就是python描述器的访问顺序,大家如果怕记忆混淆,可以记得数据访问器在最前面就行了。对于访问顺序的理解,大家不妨运行实例代码测试。
神龙|纯净稳定代理IP免费测试>>>>>>>>天启|企业级代理IP免费测试>>>>>>>>IPIPGO|全球住宅代理IP免费测试