jak*_*uta 3 python dictionary class
当创建对象的实例时,它的字典不包含类方法。一个例子是
class A(object):
def __init__(self, value):
self.value = value
def some_func(self): pass
instance = A('some_value')
print(instance.__dict__) #prints { 'value':'some_value }
Run Code Online (Sandbox Code Playgroud)
为什么它不包含方法呢?我知道打印A.__dict__将打印包含该函数的映射代理,但对于 A 的实例不会发生这种情况。
我尝试研究类的实例方法是如何映射的。如果这是使用 dict 完成的。我确实知道实例方法也有一个字典和其他预定义的属性。
class A(object)
def __init__(self, value):
self.value = value
def some_func(self): pass
instance = A('this')
instance.__dict__ # will print {'value':'some_value'}
A.__dict__ # will print a mapping proxy
Run Code Online (Sandbox Code Playgroud)
我预计结果instance.__dict__将包含所有方法和属性作为键、值对的映射。
这些方法是类的方法,而不是实例的方法。
当打电话时instance.some_func(),你实际上是在打电话A.some_func(instance)。
为了说明这一点,我向A( classattr = 'foo') 添加了一个属性:
class A:
classattr = 'foo'
def __init__(self, value):
self.value = value
def some_func(self):
return 1
instance = A('this')
print(f'instance dict : {instance.__dict__}') # will print {'value':'some_value'}
print(f'class dict : {A.__dict__}') # will print a mapping proxy
Run Code Online (Sandbox Code Playgroud)
那么在以下位置就找不到该类的这个属性instance.__dict__:
instance dict : {'value': 'this'}
class dict : {'__module__': '__main__', 'classattr': 'foo', '__init__': <function A.__init__ at 0x0000018AAB2A2400>, 'some_func': <function A.some_func at 0x0000018AAB2A2488>, '__dict__': <attribute '__dict__' of 'A' objects>, '__weakref__': <attribute '__weakref__' of 'A' objects>, '__doc__': None}
Run Code Online (Sandbox Code Playgroud)