在子类派生的新方法中如何重用父类的功能
class OldboyPeople: def __init__(self,name,age,sex): self.name=name self.age=age self.sex=sex def f1(self): print('%s say hello' %self.name) class Teacher(OldboyPeople): def __init__(self,name,age,sex,level,salary): OldboyPeople.__init__(self,name,age,sex) self.level = level self.salary=salary tea_obj=Teacher('egon',18,'male',10,3000) print(tea_obj.__dict__)
调用super()会得到一个特殊的对象,该对象会参照发起属性查找的那个类的mro,去当前类的父类中找属性
提示:在Python2中super的使用需要完整地写成super(自己的类名,self) ,而在python3中可以简写为super()。
class OldboyPeople: def __init__(self,name,age,sex): self.name=name self.age=age self.sex=sex def f1(self): print('%s say hello' %self.name) class Teacher(OldboyPeople): def __init__(self,name,age,sex,level,salary): # super(Teacher,self).__init__(name,age,sex) super().__init__(name,age,sex) # 调用的是方法,自动传入对象 self.level = level self.salary=salary # print(Teacher.mro()) tea_obj=Teacher('egon',18,'male',10,3000) print(tea_obj.__dict__)
super()案例
class A: def test(self): print('from A') super().test() class B: def test(self): print('from B') class C(A,B): pass obj=C() obj.test() print(C.mro())
这两种方式的区别是:
方式一是跟继承没有关系的,而方式二的super()是依赖于继承的,并且即使没有直接继承关系,super()仍然会按照MRO继续往后查找
当父类的方法实现不能满足子类的时候,可以对方法进行重写
重写父类的方法有两种:
1.覆盖父类方法
在开发过程中父类实现的方法与子类现完全不同,
可以使用覆盖的形式,在子类中重新编写父类的方法
具体的实现形式就是在子类中定义一个与父类同名的方法
重写父类之后,只会调用子类中重写后的方法,不会调用
父类中封装的方法
2)扩展父类方法
如果在开发的过程中,子类的方法实现中,包含父类方法的实现
父类原本封装的方法实现是子类方法的一部分
使用扩展的方式重写父类方法:
super:
(1)是python中特殊的类
(2)super()就是使用super类创建的对象
(3)常使用在重写父类方法,调用在父类中封装的方法实现
''' 重写方法就是将父类中的方法进行=重新改写----super()扩展 ''' # 创建一个动物父类 class animal(): def eat(self): print('只想吃肉,不想吃饭') def drink(self): print('喝水....') def sleep(self): print('呼呼....') #创建一个子类--狗类 class Dog(animal): def call(self,name): self.name=name print('%s--汪汪....' %self.name) #重写睡觉方法 def sleep(self): #1.针对子类特有的需求 print('神犬睡觉') #2.使用super().调用父类中原有的方法 super().sleep() #3. 增加其它子类的代码 print('$%%&*###') #创建狗类对象 dog=Dog() dog.call('哮天犬') #调用睡觉方法--------此时发现睡觉方法已经被改写了,不在是‘呼呼....'了 dog.sleep()