面向对象:减少重复代码,提高效率,比函数式编程更高效
类的创建:
实例属性又称:成员变量,成员属性(或者字段)
面向对象的三大特性:
一、封装
把客观事物封装为抽象的类,并对外只暴露一个可用接口
使用构造方法将内容封装到对象中,可通过对象直接或者通过self间接获取被封装的内容
# 创建类class Foo(object): def __init__(self, name, age): # 构造方法,根据创建的对象自动执行 self.name = name self.age = age # 类中的方法A def A(self): Foo.name = 'yeeh' print('hello!', self.name) print('hello!', Foo.name) # 类中的方法B def B(self): print('word!',self.age)obj = Foo('Vera', 18)obj.age = 12obj.A()obj.B()
hello! Verahello! yeehword! 12
二、继承
子类拥有父类的全部方法,也可以对父类方法进行重写,并且可以定义自身的方法(一般到特殊,父类定义一些公共的方法,子类可定义自身特殊的方法)
- 注:Python中一个子类可以继承多个父类
对于实例属性要进行 :先重写,再继承
# 父类class People(object): number = 0 def __init__(self, name, age, sex): self.name = name self.age = age self.sex = sex self.drink() # 因为继承,所以调用的时候,都会打印drink ()里的东西 def eat(self): print('都可以吃东西!') def drink(self): People.number += 1 print('[%s].[%s] 的年龄是[%s]' % (People.number, self.name, self.age))# 子类1class good_person(People): def __init__(self, name, age, sex, goodness): # 先重写 super(good_person, self).__init__(name, age, sex) # 再继承 self.goodness = goodness def good_ness(self): print('善良的[%s]做好事' % self.name)# 子类2class bad_person(People): def __init__(self, name, age, sex, sourness): super(bad_person, self).__init__(name, age, sex) self.sourness = sourness def bad_ness(self): print('坏人[%s]做坏事!' % self.name)g1 = good_person('花花', 23, '女', '做好事') # 实例化后因为父类的继承,所以直接会打印drink()g1.good_ness()b1 = bad_person('李刚', 33, '男', '做了坏事') b1.bad_ness()b1.eat() # 继承会继承父类的所有方法
[1].[花花] 的年龄是[23]善良的[花花]做好事[2].[李刚] 的年龄是[33]坏人[李刚]做坏事!都可以吃东西!
注:
新式类 继承的写法:super(Teacher,self).__init__(name,age,sex) # 利用关键字super
旧式(经典)类 继承的写法:SchoolMember.__init__(self,name,age,sex)
多继承:
- 在3.0里及以后多继承的经典类和新式类都是采用的广度优先原则
- 在3.0以下的版本,经典类和新式类就有深度和广度的区分
经典类:class A: 深度优先:继承了上一级里没有这个方法就直接到上一级的上一级去寻找,找到始祖没有找到,再从继承的上一级寻找再到它的始祖
新式类:class A(object): 广度优先 :继承的上一级,从左到右依次寻找继承的类里有没有那个方法,如果没有才再寻找上一级的上一级所继承的
class A(object): def f1(self): print('我是 A')class B(A): def f2(self): print('我是 B')class C(A): def f3(self): print('我是 C')class D(B, C): def f4(self): print('我是 D')d = D()d.f1() # D->B->C->Ad.f2() # D->Bd.f3() # D->B->Cd.f4() # D
class A: def f1(self): print('我是 A')class B(A): def f2(self): print('我是 B')class C(A): def f3(self): print('我是 C')class D(B, C): def f4(self): print('我是 D')d = D()d.f1() # D->B->Ad.f2() # D->Bd.f3() # D->B->A->Cd.f4() # D
我是 A我是 B我是 C我是 D
三、多态
多态:当子类和父类都存在相同的方法时,子类的 方法 覆盖了父类的方法,在代码运行时,会调用子类的方法(一种调用方式,拥有不同的执行效果),把接口进行统一但(外部调用,内部可以直接转换到相应方法下)
class Animal(object): def func(self): print('这是Animal。。') def print_func(slef, animal): # 不知道这里对不对。。 animal.func() class dog(Animal): def func(self): print('这是dog。。')class pig(Animal): def func(self): print('这是pig。。') def run(self): print('这是pig中的run....')A = Animal()d = dog()p = pig()A.print_func(Animal()) # 对外只暴露一个接口,但是可以直接打印多个不同的东西A.print_func(dog())A.print_func(pig())
这是Animal。。这是dog。。这是pig。。