python笔记58-类里面的__dict__属性

前言

python是面向对象的,对象有属性和方法,可以通过__dict__查看对象的属性

__dict__查看对象属性

首先弄清楚2个概念,类(A)和类的实例对象(A()), 如下代码

  • count 是A的类属性
  • name和age是 A类的实例对象A()属性
  • start 是实例方法,默认带self参数
  • stop 是静态方法,可以不带默认参数
  • open 是类方法,默认带cls参数
class A(object):
    count = 0

    def __init__(self):
        self.name = "yoyo"
        self.age = 18

    def start(self):
        """实例方法"""
        print("start-11111")

    @staticmethod
    def stop():
        """静态方法"""
        print("stop-22222")

    @classmethod
    def open(cls):
        print("open-3333333")

A类有属性和方法,抽象的来讲,方法也可以看成类的属性(方法属性)

print(A.__dict__)  # A类属性
a = A()    # a是A类的实例对象
print(a.__dict__)   # A类的实例对象属性

运行结果

{'__module__': '__main__', 'count': 0, '__init__': <function A.__init__ at 0x000001F84781AAE8>, 'start': <function A.start at 0x000001F84781AB70>, 'stop': <staticmethod object at 0x000001F84783A2B0>, 'open': <classmethod object at 0x000001F84783A2E8>, '__dict__': <attribute '__dict__' of 'A' objects>, '__weakref__': <attribute '__weakref__' of 'A' objects>, '__doc__': None}
{'name': 'yoyo', 'age': 18}

从运行结果可以看出,A的类属性有count,还有定义的一些方法(__init__构造方法,还有实例方法,静态方法,类方法)
A()实例对象只有__init__构造方法里面的name和age属性(count是类属性,并不是类的实例对象属性)

如果我们直接A.name 和 A.age就会报错

print(A.name)
print(A.age)

报错

Traceback (most recent call last):
  File "D:/wangyiyun_hrun3/demo/a.py", line 27, in <module>
    print(A.name)
AttributeError: type object 'A' has no attribute 'name'

因为name和age属性在__init__构造方法里面,只有当A类实例化的时候,才会执行__init__构造方法,这时候才会有name和age属性了

继承时__dict__属性

当B类继承A类的时候,A类和B类都有自己的类属性 count,也各自有自己的__init__构造方法

class A(object):
    count = 0

    def __init__(self):
        self.name = "yoyo"
        self.age = 18

    def start(self):
        """实例方法"""
        print("start-11111")

    @staticmethod
    def stop():
        """静态方法"""
        print("stop-22222")

    @classmethod
    def open(cls):
        print("open-3333333")


class B(A):
    count = 22

    def __init__(self):
        super().__init__()
        self.name = "hello"
        self.age = 22
    def new(self):
        print("new--44444")

print(A.__dict__)
print(B.__dict__)
a = A()
b = B()
print(a.__dict__)
print(b.__dict__)

运行结果

{'__module__': '__main__', 'count': 0, '__init__': <function A.__init__ at 0x000001FD03F8AAE8>, 'start': <function A.start at 0x000001FD03F8AB70>, 'stop': <staticmethod object at 0x000001FD03FAA470>, 'open': <classmethod object at 0x000001FD03FAA4A8>, '__dict__': <attribute '__dict__' of 'A' objects>, '__weakref__': <attribute '__weakref__' of 'A' objects>, '__doc__': None}
{'__module__': '__main__', 'count': 22, '__init__': <function B.__init__ at 0x000001FD03F8AD08>, 'new': <function B.new at 0x000001FD03F8AD90>, '__doc__': None}
{'name': 'yoyo', 'age': 18}
{'name': 'hello', 'age': 22}

从运行结果可以看出

  • A类和B类的类属性count是不一样的,
  • 虽然B类继承了A类,方法属性也不一样,可以清楚的区分出哪些是A类的方法属性,哪些是B类的方法属性
posted @ 2021-08-17 15:35  上海-悠悠  阅读(470)  评论(0编辑  收藏  举报