封装
封装:指隐藏对象的属性和实现细节,不允许外部直接方位对象内部的信息,仅仅提供公共的访问方式给外部,实现外部对内部的操作和访问。
封装的目的:
- 保护隐私数据和方法,明确内外区分。
- 隔离复杂的实现方法
封装的益处:
- 便于使用
- 提高代码的复用性
- 隔离变化和复杂性
- 提高安全性
封装分为两个层面
第一个层面的封装(什么都不用做):创建类和对象会分别创建二者的名称空间,我们只能用类名.或者obj.的方式去访问里面的名字,这本身就是一种封装
注意:对于这一层面的封装(隐藏),类名.和实例名.就是访问隐藏属性的接口
第二个层面的封装:类中把某些属性和方法隐藏起来(或者说定义成私有的),只在类的内部使用、外部无法访问,或者留下少量接口(函数)供外部访问。
注意:对于这一层面的封装(隐藏),我们需要在类中定义一个函数(接口函数)在它内部访问被隐藏的属性,然后外部就可以使用了
-
类中定义的__x只能在内部使用,如self.__x,引用的就是变形的结果。
-
这种变形其实正是针对外部的变形,在外部是无法通过__x这个名字访问到的。
-
在子类定义的__x不会覆盖在父类定义的__x,因为子类中变形成了:_子类名__x,而父类中变形成了:_父类名__x,即双下滑线开头的属性在继承给子类时,子类是无法覆盖的。
这种变形需要注意的问题是:
-
这种机制也并没有真正意义上限制我们从外部直接访问属性,知道了类名和属性名就可以拼出名字:_类名__属性,然后就可以访问了
-
变形的过程只在类的定义是发生一次,在定义后的赋值操作,不会变形
-
在继承中,父类如果不想让子类覆盖自己的方法,可以将方法定义为私有的
继承
继承概念:继承是类与类的一种关系,是一种子类与父类的关系,即爸爸与儿子,爸爸生个儿子,儿子继承爸爸的属性和方法。
类的继承方式分为:单继承、多继承两种
单继承
-
子类继承父类的属性和方法,私有属性除外
-
利用super()函数,我们可以选择调用父类的函数,很多时候我们都需要在子类的初始化函数中调用父类的初始化函数__init__()
-
子类和父类有相同的属性和方法,优先调用子类的属性和方法
多继承
-
在子类中没有对应方法后,开始在父类中寻找对应方法,寻找是按照一个顺序进行的,这个顺序就存放在类的__mro__成员变量中。(object是python中所有定义的类的超类,在python2中,自定义的类都要继承自object,python3中则不需要再显示的写出来,但是仍然会继承自object)
-
python会在MRO列表上从左到右查找基类,直到找到第一个匹配这个属性的类为止。而这个MRO列表的构造是通过一个C3线性化算法来实现的
- 子类会由于父类被检查;
- 多个父类会根据他们在列表中的顺序被检查;
- 如果对于下一个类存在两个合法的选择,应选择第一个父类;
经典类:用作MRO的算法是DFS(深度优先)
新式类:用作MRO的算法是BFS(广度优先)
多态
作用:让具有不同功能的函数可以使用相同的函数名,这样就可以用一个函数名调用不同内容(功能)的函数。
特点:
- 只关心对象的实例方法是否同名,不关心对象所属的类型;
- 对象所属的类之间,继承关系可有可无;
- 多态的好处可以增加代码的外部调用灵活度,让代码更加通用,兼容性比较强;
- 多态是调用方法的技巧,不会影响到类的内部设计。
应用场景 :
- 对象所属的类之间没有继承关系
- 对象所属的类之间有继承关系(应用更广)
总结:
Java中多态性的表现: 多态性,可以理解为一个事物的多种形态。同样python中也支持多态,但是是有限的的支持多态性,主要是因为python中变量的使用不用声明,所以不存在父类引用指向子类对象的多态体现,同时python不支持重载。在python中 多态的使用不如Java中那么明显,所以python中刻意谈到多态的意义不是特别大。
鸭子类型
鸭子类型是动态类型的一种风格。在这种风格中,一个对象有效的语义,不是由继承自特定的类或实现特定的接口,而是由"当前方法和属性的集合"决定。
- 什么是鸭子模型
- 当看到一只鸟走起来像鸭子,游泳起来也像鸭子,叫起来也像鸭子,那么这只鸟就可以被称为鸭子
- 鸭子模型和多态一样,都是接受不同的类对象,并调用相同的方法(即:鸭子的 游泳 和 叫 方法)
- 对于一个鸭子模型来说,我们并 不关心接收的类对象是否真的是鸭子类,只关心这个类是如何被使用的
- 注意:如果这些需要被调用的方法不存在,那么将引发一个运行时错误
---------------------------------------------------END-----------------------------------------------
---------------------------------------------------END-----------------------------------------------