Python中的类和对象
未完待续
1.定义类
python3中的根类,有且只有一个:object(小写)
⚠️大写的Object不存在于python内置中,是自己定义的,为防止混淆不建议使用
__bases__是python中一个内置的变量,代表基类
# 隐式继承,python3自动处理class Cat: pass# 显式继承class Dog(object): passif __name__ == '__main__': print( Cat.__bases__ ) # (<class 'object'>,) print( Dog.__bases__ ) # (<class 'object'>,)2.构造方法
- python初始化类的对象,使用
__init__()这个特殊方法作为类的构造方法,创建对象时会被自动调用。 - python构造方法不支持重载,不能弄多个
__init__(),否则最后一个覆盖前面的。
类的方法和普通函数存在区别,类的方法第一个参数必须是
self代表当前对象
class Cat: def __init__(self): print('init') print(self) print(self.__class__)if __name__ == '__main__': cat = Cat() print(cat)init<__main__.Cat object at 0x000001982BE1D400><class '__main__.Cat'><__main__.Cat object at 0x000001982BE1D400>3.类的成员
3.1 类和实例的属性
- 实例属性在构造器
__init__中声明,__init__()中通过self.定义实例属性 - 定义在
__init__()外面的属性是类属性,类似Java中的static - 实例属性和类属性不同名时,实例属性通过
对象.访问,类属性可以通过类.访问或对象.访问 - 实例属性和类属性同名是合法但是不推荐的,这种情况下,实例和类会各自有一份,
对象.访问到的是实例属性,类属性只能通过类.访问
⚠️
__init__()外面的同名属性前面没有static且和self.后面的属性名重名时,self.极易被Java程序员误判为是在为外面的属性初始化或赋值,这种Java的思路,在python中是错误的
例:
__init__()里面的重名name,age是实例属性,通过对象.访问__init__()外面的重名name,age是类属性,通过类.访问country属性不重名,可通过对象.访问,也可以通过类.访问
class Stu: name = 'simaple_name' age = 0 country = 'China' def __init__(self, age, name): print('init') self.age = age self.name = name def speak(self): print(self.age, self.name)if __name__ == '__main__': stu1 = Stu(18, '元宝') stu2 = Stu(20, '大黄') stu1.speak() stu2.speak() print('---------------') print(Stu.name) print(Stu.age) print('-------------') print(stu1.country) print(stu2.country) print(Stu.country)initinit18 元宝20 大黄---------------simaple_name0-------------ChinaChinaChina














