Python对象实例中的dict不包含类的方法

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__将包含所有方法和属性作为键、值对的映射。

Max*_*mGi 8

这些方法是类的方法,而不是实例的方法。

当打电话时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)