1 oop 对象世界观 -- oop是目前人类认知最接近实际生活的语言
- 一切事务皆对象
- 对象有运动规律和内部状态
- 对象之间可以相互调用
2.面向对象
- 唯一性:对象具有唯一性,不存在两个相同的对象,除非他们是同一个对象
- 可以分类性 : 对象可以分类
3.oop 分类
- 封装
- 继承
- 多态
具体类:
结构
classs 类名:
类体
- 创建对象使用类名(__init__ 函数除第一个参数外的参数列表)
- 创建对象的时候 实际执行了
__init__
函数, __init__ 并不会创建对象,但会初始化对象 - 当使用对象来调用方法的时候,第一个参数会自动的传入(默认是self,这个self这四个字母可以替换成任意字符,但位置必须是第一个)
作用域
- 类的直接下级作用域 叫做类变量
- 关联到实例的变量 叫做实例变量
例子:
1 class E:2 NAME = 'E' # 类的直接下级作用域 叫做类变量3 4 def __init__(self, name):5 self.name = name # 关联到实例的变量 叫做实例变量
- 类变量对类和实例都可见
- 所有实例共享类变量
- Python 可动态的给对象增减属性,当给实例的类变量赋值时,相当于动态的给这个实例增加了一个属性,覆盖了类变量
属性的查找顺序
-
__dict__ :当通过对象动态增加属性的时候,如果存在此属性,会覆盖原属性,不存在会存放到对象.__dict__中。
-
__class__ : 如果通过类名.类属性方式给类属性重新赋值,原类属性会被覆盖
--------------------------------------------------- 只需要对象.__dict__ 来看其内容能分辨-----------------------------------------------------------------------------
类装饰器通常用于给类增加属性-- 方法都是类级的
类方法/静态方法
方法的定义都是类级的,但是有的方法使用实例调用,有的方法使用类来调用
class I: def print(self): print('instance method') @classmethod # 当一个方法,被classmethod装饰的时候, 第一个参数会变成类本身, 这样的方法叫类方法 def class_print(cls): print(id(cls)) print('class method') @staticmethod # 当一个方法, 被staticmethod装饰的时候,不会自动传递第一个参数, 这样的方法叫静态方法 def static_print(): print('static method') def xxx_print(): print('this is a function')
实例方法只能由实例调用
类方法:类方法可以被实例使用,并且被实例使用时,传入的第一个参数还是类
访问控制
class Door: def __init__(self, number, status): self.number = number self.__status = status # 双下划线开始, 非双下划綫结尾的都是私有的, 在类外部无法访问 def open(self): # 方法 self.__status = 'opening' def close(self): self.__status = 'closed' def status(self): return self.__status def __set_number(self, number): # 双下滑先开始, 非双下划线结尾的方法也是私有方法 self.number = number
所有双下划线开始,非双下划线结尾的成员,都是私有成员
私有成员在类外部无法访问
Python的私有成员是通过改名实现的,_类名 + 带双下划綫的属性 在__dict__ 中会有标识(python中没有真正的私有成员,但这可以忽略不计)
部分代码中 用单下划线标注的变量可以理解为内部变量,不希望在外部继续调用(其实外部可以调用),解释器不不做任何处理
双下划线开始,非双下划线结尾的方法是私有方法。
如果用 @property 装饰器会把一个仅有self参数的函数,变成一个属性, 属性的值,为方法的返回值
class Door: def __init__(self, status): self.__status = status # 双下划线开始, 非双下划綫结尾的都是私有的, 在类外部无法访问 @property # property 装饰器会把一个仅有self参数的函数,变成一个属性, 属性的值,为方法的返回值 def status(self): return self.__status
d = Door('opening')print(d.status) status 为 Door 中 status方法
类的继承
- 在类名后加括号 括号中是继承列表, 称之为父类或者基类或者超类- python中不建议多继承
- 继承一个明显的好处就是可以获取父类的属性和方法,深层次继承会比较乱
- 凡是公有的都能继承
- 凡是私有的都不能继承
- 原来是什么,继承过来还是什么
- 当子类和父类有同名成员的时候, 子类的成员会覆盖父类的同名成员
-
super(父类, self).print() # 代理 TYPE 的父类的方法, 并且使用 obj 绑定 第一个参数 指定调用谁的直接父类, 第二个参数指定当调用时,传递什么作为方法的第一个参数
- 当父类含有一个带参数的初始化方法的时候,子类一定需要一个初始化方法,并且在初始化方法中调用父类的初始化方法
class Base: def __init__(self, a, b): self.__a = a self.__b = b def sum(self): return self.__a + self.__b
class Sub(Base): def __init__(self, a, b, c): self.c = c# self.__a = a# self.__b = b super().__init__(a, b)
-
super 对象只能获取类的属性