1.在子类派生的新方法中重用父类功能的方式二
# 1在子类派生的新方法中重用父类的功能
# 方式一:指名道姓地调用某一个类的函数
# 特点:不依赖于继承关系
#
# class OldboyPeople:
# school = "oldboy"
# # 空对象,"艾利克斯",73,'male'
# def __init__(self,name,age,gender):
# self.name = name
# self.age = age
# self.gender = gender
#
# def f1(self):
# print('1111111')
#
# class Student(OldboyPeople):
# # 空对象,"艾利克斯",73,'male',1001,"python全栈开放"
# def __init__(self,name,age,gender,stu_id,course):
# OldboyPeople.__init__(self,name,age,gender) # OldboyPeople.__init__(空对象,"艾利克斯",73,'male')
# self.stu_id = stu_id
# self.course = course
#
#
# def choose(self):
# print('%s 正在选课' %self.name)
#
# def f1(self):
# OldboyPeople.f1(self)
# print("22222")
#
# stu1=Student("艾利克斯",73,'male',1001,"python全栈开放")
# # tea1=Teacher("egon",18,'male',2000,10)
#
#
# stu1.f1()
# 2 在子类派生的新方法中重用父类功能的方式二
# 方式一:调用super(自己的类名,self)会返回一个特殊的对象,super(自己的类名,self).属性,会参照属性查找发起的那个类的mro列表去它父类中查找属性
# 特点:严格依赖于继承关系
# class OldboyPeople:
# school = "oldboy"
# # 空对象,"艾利克斯",73,'male'
# def __init__(self,name,age,gender):
# self.name = name
# self.age = age
# self.gender = gender
#
# def f1(self):
# print('1111111')
#
# class Student(OldboyPeople):
# def __init__(self,name,age,gender,stu_id,course):
# # OldboyPeople.__init__(self,name,age,gender) # OldboyPeople.__init__(空对象,"艾利克斯",73,'male')
# super(Student,self).__init__(name,age,gender)
# self.stu_id = stu_id
# self.course = course
#
#
# def choose(self):
# print('%s 正在选课' %self.name)
#
# def f1(self):
# # OldboyPeople.f1(self)
# # super().f1()
# print("22222")
#
# # print(Student.mro())
# stu1=Student("艾利克斯",73,'male',1001,"python全栈开放")
# # print(stu1.__dict__)
# stu1.f1()
#3:
# class A:
# def test(self):
# super().test()
# class B:
# def test(self):
# print('from B')
# class C(A,B):
# pass
# c=C()
# print(C.mro())
# c.test()
# obj=A()
# obj.test()
#4:
class A:
def test(self):
print('A---->test')
super().aaa()
class B:
def test(self):
print('B---->test')
def aaa(self):
print('B---->aaa')
class C(A,B):
def aaa(self):
print('C----->aaa')
c=C()
print(C.mro())
c.test()
"""