继承简介 | Python从入门到精通:高阶篇之二十九

简介: 本节重点讲了继承是面向对象的三大特性之一,以及子类继承父类的用法。

property装饰器 | Python从入门到精通:高阶篇之二十八

继承

定义一个类 Animal(动物),这个类中需要两个方法:run()、 sleep() 。

class Animal:
    def run(self):
        print('动物会跑~~~')

    def sleep(self):
        print('动物睡觉~~~')

a = Animal()

a.run()

执行结果:

image.png

现在还想定义一个类,Dog(狗),这个类中需要三个方法:run()、 sleep() 、bark()。

有一个类,能够实现我们需要的大部分功能,但是不能实现全部功能。
如何能让这个类来实现全部的功能呢?
① 直接修改这个类,在这个类中添加我们需要的功能

class Animal:
    def run(self):
        print('动物会跑~~~')

    def sleep(self):
        print('动物睡觉~~~')

    def bark(self):
        print('动物嚎叫~~~')  

这种方式修改起来会比较麻烦,并且会违反OCP原则。(开闭原则),我们不推荐使用这种方式。
② 直接创建一个新的类

class Dog:
    def run(self):
        print('狗会跑~~~')

     def sleep(self):
        print('狗睡觉~~~')

    def bark(self):
        print('汪汪汪~~~') 

创建一个新的类比较麻烦,并且需要大量的进行复制粘贴,会出现大量的重复性代码。这种方式也不太适合。
③ 直接从Animal类中来继承它的属性和方法

  • 继承是面向对象三大特性之一
  • 通过继承我们可以使一个类获取到其他类中的属性和方法
  • 在定义类时,可以在类名后的括号中指定当前类的父类(超类、基类、super),子类(衍生类)可以直接继承父类中的所有的属性和方法
class Dog(Animal):
    def bark(self):
        print('汪汪汪~~~') 

    
d = Dog()

d.run()
d.sleep()
d.bark()

执行结果:

image.png

继承的优势:
通过继承可以直接让子类获取到父类的方法或属性,避免编写重复性的代码,并且也符合OCP原则,所以我们经常需要通过继承来对一个类进行扩展。

检查一个对象是否是另外一个的实例

r = isinstance(d , Dog)
#r = isinstance(d , Animal)
print(r)

执行结果:

image.png
image.png

定义一个哈士奇类:

class Hashiqi(Dog):
    def fan_sha(self):
        print('我是一只傻傻的哈士奇')        

d = Dog()
h = Hashiqi()

哈士奇类可以继dog类。

在创建类时,如果省略了父类,则默认父类为object,object是所有类的父类,所有类都继承自object。

class Person(object):
    pass

issubclass() 检查一个类是否是另一个类的子类

#print(issubclass(Dog, Animal ))
#print(issubclass(Animal , Dog))
#print(issubclass(Animal , object))
print(issubclass(Person , object))

执行结果:

image.png
image.png
image.png
image.png

isinstance()用来检查一个对象是否是一个类的实例。

  • 如果这个类是这个对象的父类,也会返回True
  • 所有的对象都是object的实例
#print(isinstance(d , object))
#print(isinstance(h , object))
print(isinstance(print , object))

执行结果:

image.png
image.png
image.png

继承的确减少了我们的代码量,但现在有另外问题:

class Dog(Animal):
    def bark(self):
        print('汪汪汪~~~') 

    def run(self):
        print('狗跑~~~~')    

class Hashiqi(Dog):
    def fan_sha(self):
        print('我是一只傻傻的哈士奇') 

d = Dog()
h = Hashiqi()

d.run()

现在子类父类都有run方法,那么结果会是执行哪个呢?我们下一节来看。

配套视频课程,点击这里查看

获取更多资源请订阅Python学习站

相关文章
|
15天前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
124 1
|
2月前
|
API 数据安全/隐私保护 开发者
Python自定义异常:从入门到实践的轻松指南
在Python开发中,自定义异常能提升错误处理的精准度与代码可维护性。本文通过银行系统、电商库存等实例,详解如何创建和使用自定义异常,涵盖异常基础、进阶技巧、最佳实践与真实场景应用,助你写出更专业、易调试的代码。
105 0
|
2月前
|
IDE 开发工具 数据安全/隐私保护
Python循环嵌套:从入门到实战的完整指南
循环嵌套是Python中处理多维数据和复杂逻辑的重要工具。本文通过实例讲解嵌套循环的基本用法、常见组合、性能优化技巧及实战应用,帮助开发者掌握其核心思想,避免常见错误,并探索替代方案与进阶方向。
111 0
|
20天前
|
调度 数据库 Python
Python异步编程入门:asyncio让并发变得更简单
Python异步编程入门:asyncio让并发变得更简单
96 5
|
4月前
|
Python
Python字符串格式化利器:f-strings入门指南
Python字符串格式化利器:f-strings入门指南
225 80
|
1月前
|
数据采集 存储 XML
Python爬虫入门(1)
在互联网时代,数据成为宝贵资源,Python凭借简洁语法和丰富库支持,成为编写网络爬虫的首选。本文介绍Python爬虫基础,涵盖请求发送、内容解析、数据存储等核心环节,并提供环境配置及实战示例,助你快速入门并掌握数据抓取技巧。
|
1月前
|
大数据 数据处理 数据安全/隐私保护
Python3 迭代器与生成器详解:从入门到实践
简介:本文深入解析Python中处理数据序列的利器——迭代器与生成器。通过通俗语言与实战案例,讲解其核心原理、自定义实现及大数据处理中的高效应用。
77 0
|
1月前
|
存储 缓存 安全
Python字典:从入门到精通的实用指南
Python字典如瑞士军刀般强大,以键值对实现高效数据存储与查找,广泛应用于配置管理、缓存、统计等场景。本文详解字典基础、进阶技巧、实战应用与常见陷阱,助你掌握这一核心数据结构,写出更高效、优雅的Python代码。
44 0
|
2月前
|
数据挖掘 数据处理 C++
Python Lambda:从入门到实战的轻量级函数指南
本文通过10个典型场景,详解Python中Lambda匿名函数的用法。Lambda适用于数据处理、排序、条件筛选、事件绑定等简洁逻辑,能提升代码简洁性和开发效率。同时提醒避免在复杂逻辑中过度使用。掌握Lambda,助你写出更高效的Python代码。
124 0

热门文章

最新文章

推荐镜像

更多