Python教程:类的继承,什么是继承,要找出这种关系,必须


一、什么是继承

  • 继承是一种新建类的方式,新建的类称为子类,被继承的类称为父类
  • 继承的特性是:子类会遗传父类的属性
  • 继承是类与类之间的关系

二、为什么用继承

使用继承可以减少代码的冗余

三、对象的继承

Python中支持一个类同时继承多个父类

class Parent1:
    pass


class Parent2:
    pass


class Sub1(Parent1, Parent2):
    pass

使用__bases__方法可以获取对象继承的类

print(Sub1.__bases__)

(<class '__main__.Parent1'>, <class '__main__.Parent2'>)
  • 在Python3中如果一个类没有继承任何类,则默认继承object类
  • 在Python2中如果一个类没有继承任何类,不会继承object类
print(Parent1.__bases__)

(<class 'object'>,)

四、类的分类

后面会详细解释类的分类,目前仅做了解

1 新式类

继承了object的类以及该类的子类,都是新式类
Python3中所有的类都是新式类

2 经典类

没有继承object的类以及该类的子类,都是经典类
只有Python2中才有经典类

五、继承与抽象

继承描述的是子类与父类之间的关系,是一种什么是什么的关系。要找出这种关系,必须先抽象再继承,抽象即抽取类似或者说比较像的部分。

抽象分成两个层次:

  • 将奥巴马和梅西这俩对象比较像的部分抽取成类;
  • 将人,猪,狗这三个类比较像的部分抽取成父类。

抽象最主要的作用是划分类别(可以隔离关注点,降低复杂度),如下图所示:

继承:基于抽象的结果,通过编程语言去实现它,肯定是先经历抽象这个过程,才能通过继承的方式去表达出抽象的结构。

抽象只是分析和设计的过程中,一个动作或者说一种技巧,通过抽象可以得到类,如下图所示:

六、继承的应用

牢记对象是特征与功能的集合体,我们可以拿选课系统举例

class OldboyPeople:
    """由于学生和老师都是人,因此人都有姓名、年龄、性别"""
    school = 'oldboy'

    def __init__(self, name, age, gender):
        self.name = name
        self.age = age
        self.gender = gender


class OldboyStudent(OldboyPeople):
    def choose_course(self):
        print('%s is choosing course' % self.name)


class OldboyTeacher(OldboyPeople):
    def score(self, stu_obj, num):
        print('%s is scoring' % self.name)
        stu_obj.score = num


stu1 = OldboyStudent('tank', 18, 'male')
tea1 = OldboyTeacher('nick', 18, 'male')

对象查找属性的顺序:对象自己-》对象的类-》父类-》父类。。。

rint(stu1.school)
oldboy

print(tea1.school)
oldboy

print(stu1.__dict__)
{'name': 'tank', 'age': 18, 'gender': 'male'}

#学习中遇到问题没人解答?小编创建了一个Python学习交流群:711312441
tea1.score(stu1, 99)
nick is scoring

print(stu1.__dict__)
{'name': 'tank', 'age': 18, 'gender': 'male', 'score': 99}

1 属性查找练习

class Foo:
    def f1(self):
        print('Foo.f1')

    def f2(self):
        print('Foo.f2')
        self.f1()


class Bar(Foo):
    def f1(self):
        print('Bar.f1')


# 对象查找属性的顺序:对象自己-》对象的类-》父类-》父类。。。
obj = Bar()  # self是obj本身,即找到Bar的f1()
obj.f2()

输出

Foo.f2
Bar.f1

评论关闭