当前位置: 首页 > news >正文

【python】深入探讨python中的抽象类,创建、实现方法以及应用实战

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,PyQt5和Tkinter桌面开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,云原生K8S,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:python综合应用,基础语法到高阶实战教学
景天的主页:景天科技苑

在这里插入图片描述

文章目录

  • Python抽象类
    • 一、抽象类和抽象方法的基本概念
      • 1.1 抽象类
      • 1.2 抽象方法
      • 1.3 为什么要有抽象类
    • 二、Python中实现抽象类的步骤
      • 2.1 导入`abc`模块
      • 2.2 定义抽象基类
      • 2.3 实现抽象方法
      • 2.4 实例化子类
    • 三、实际案例:文件操作抽象类
      • 3.1 定义文件操作抽象基类
      • 3.2 实现文件操作抽象类
        • 3.2.1 文本文件操作类
        • 3.2.2 二进制文件操作类
      • 3.3 使用文件操作类
    • 四、抽象类的其他用途
      • 4.1 强制接口实现
      • 4.2 插件系统
      • 4.3 框架设计
      • 4.4 单元测试
    • 五、总结

Python抽象类

在Python中,抽象类是一种特殊的类,它不能被直接实例化,而是作为其他类的基类,用于定义一组接口规范,确保派生类(子类)实现特定的方法。抽象类通过强制子类实现特定的方法来提供代码的规范性和可维护性。本文将详细讲解Python中抽象类的用法,并结合实际案例进行说明。

一、抽象类和抽象方法的基本概念

1.1 抽象类

抽象类是一种特殊的类,它包含至少一个抽象方法。在Python中,抽象类不能直接被实例化,它主要用于定义一组接口规范,要求子类必须实现这些接口。抽象类通过abc模块中的ABC类和abstractmethod装饰器来实现。

1.2 抽象方法

抽象方法是一种在基类中声明但不提供具体实现的方法。在Python中,使用@abstractmethod装饰器来标记抽象方法。抽象方法只有方法签名,没有方法体(通常使用pass语句作为占位符)。任何继承自包含抽象方法的类的子类都必须实现这些抽象方法,否则子类也不能被实例化。

1.3 为什么要有抽象类

如果说类是从一堆对象中抽取相同的内容而来的,那么抽象类就是从一堆类中抽取相同的内容而来的,内容包括数据属性和函数属性。

比如我们有梨的类,有苹果的类,有桃子的类,从这些类抽取相同的内容就是水果这个抽象的类,你吃水果时,要么是吃一个具体的梨,要么是吃一个具体的桃子… 你永远不可能吃到一个叫做水果的东西。

从设计角度去看,如果类是从现实对象抽象而来的,那么抽象类就是基于类抽象而来的。

从实现角度来看,抽象类与普通类的不同之处在于:抽象类中只能有抽象方法(没有实现功能),该类不能被实例化,只能被继承,且子类必须实现抽象方法。

二、Python中实现抽象类的步骤

2.1 导入abc模块

首先,需要从Python的abc模块中导入ABC类和abstractmethod装饰器。

from abc import ABC, abstractmethod

2.2 定义抽象基类

通过继承ABC类来定义一个抽象基类,并在其中使用@abstractmethod装饰器来声明抽象方法。

class Shape(ABC):@abstractmethoddef area(self):pass@abstractmethoddef perimeter(self):pass

在这个例子中,Shape是一个抽象基类,它定义了两个抽象方法areaperimeter。任何继承自Shape的类都必须实现这两个方法。

2.3 实现抽象方法

接下来,定义一个或多个继承自抽象基类的子类,并实现抽象基类中的所有抽象方法。

class Circle(Shape):def __init__(self, radius):self.radius = radiusdef area(self):return 3.14 * self.radius * self.radiusdef perimeter(self):return 2 * 3.14 * self.radiusclass Rectangle(Shape):def __init__(self, width, height):self.width = widthself.height = heightdef area(self):return self.width * self.heightdef perimeter(self):return 2 * (self.width + self.height)

在这个例子中,CircleRectangle都继承自Shape,并实现了areaperimeter方法。

2.4 实例化子类

由于抽象类不能被实例化,因此只能实例化实现了所有抽象方法的子类。

circle = Circle(5)
rectangle = Rectangle(4, 6)print("Circle Area:", circle.area())
print("Rectangle Area:", rectangle.area())
print("Circle Perimeter:", circle.perimeter())
print("Rectangle Perimeter:", rectangle.perimeter())

运行效果
在这里插入图片描述

三、实际案例:文件操作抽象类

为了更好地理解抽象类的用法,我们将通过一个实际案例——文件操作抽象类来详细讲解。

3.1 定义文件操作抽象基类

首先,我们定义一个文件操作抽象基类FileOperation,它包含两个抽象方法readwrite,分别用于读取和写入文件。

from abc import ABC, abstractmethodclass FileOperation(ABC):@abstractmethoddef read(self, filepath):pass@abstractmethoddef write(self, filepath, content):pass

3.2 实现文件操作抽象类

接下来,我们定义两个继承自FileOperation的子类,分别用于处理文本文件和二进制文件的读写操作。

3.2.1 文本文件操作类
class TextFileOperation(FileOperation):def read(self, filepath):with open(filepath, 'r', encoding='utf-8') as file:return file.read()def write(self, filepath, content):with open(filepath, 'w', encoding='utf-8') as file:file.write(content)
3.2.2 二进制文件操作类
class BinaryFileOperation(FileOperation):def read(self, filepath):with open(filepath, 'rb') as file:return file.read()def write(self, filepath, content):with open(filepath, 'wb') as file:file.write(content)

3.3 使用文件操作类

现在,我们可以使用TextFileOperationBinaryFileOperation类来执行文件的读写操作了。

# 文本文件操作
text_file_op = TextFileOperation()
text_file_op.write('example.txt', 'Hello, World!')
content = text_file_op.read('example.txt')
print("Text file content:", content)# 二进制文件操作
# 假设我们有一个名为'image.png'的图片文件
binary_file_op = BinaryFileOperation()
image_content = binary_file_op.read("image.png")
binary_file_op.write('copy_of_image.png', image_content)# 注意:由于二进制内容通常不是文本,所以我们不会直接打印它
# 但可以验证'copy_of_image.png'文件是否被正确创建和复制

运行前,我们先看下原图片
在这里插入图片描述

运行代码
在这里插入图片描述

查看生成的图片
在这里插入图片描述

四、抽象类的其他用途

4.1 强制接口实现

抽象类的一个主要用途是强制子类实现特定的接口。这有助于确保类的继承体系中的一致性,并使得代码更加易于理解和维护。

4.2 插件系统

在开发插件系统时,抽象类可以定义插件必须实现的接口。这样,插件开发者只需要关注如何实现这些接口,而不必担心如何与系统的其他部分集成。

4.3 框架设计

在设计大型框架时,抽象类可以用来定义框架的核心组件和它们之间的交互方式。这样,框架的使用者可以通过继承抽象类并实现特定的方法来扩展框架的功能。

4.4 单元测试

在编写单元测试时,可以使用抽象类来定义测试框架。子类可以继承这个抽象类并实现具体的测试方法,从而方便地进行单元测试。

五、总结

Python中的抽象类是一种强大的工具,它允许我们定义接口规范并强制子类实现这些规范。通过使用抽象类和抽象方法,我们可以提高代码的可读性、可维护性和可扩展性。在实际开发中,抽象类广泛应用于框架设计、插件系统、单元测试等多个领域。希望本文能够帮助读者更好地理解抽象类的用法,并在实际项目中灵活运用。

相关文章:

【python】深入探讨python中的抽象类,创建、实现方法以及应用实战

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…...

微前端传值

在微前端架构中,不同子应用之间通过 postMessage 进行通信是一种常见的做法。这种方式允许不同源的窗口之间进行安全的信息交换。 下面是如何使用 postMessage 在微前端环境中发送和接收消息的示例。 步骤 1: 发送消息 假设您有一个主应用(host app&a…...

《学会 SpringBoot · 依赖管理机制》

📢 大家好,我是 【战神刘玉栋】,有10多年的研发经验,致力于前后端技术栈的知识沉淀和传播。 💗 🌻 CSDN入驻不久,希望大家多多支持,后续会继续提升文章质量,绝不滥竽充数…...

全网行为管理软件有哪些?5款总有一款适合你的企业!

如今企业越来越依赖互联网进行日常运营和业务发展,网络行为管理变得日益重要。 为了确保网络安全、提高员工工作效率、避免敏感信息外泄等问题,企业往往需要借助全网行为管理软件来监控和管理内部网络的使用情况。 本文将为您介绍五款热门的全网行为管理…...

以简单的例子从头开始建spring boot web多模块项目(二)-mybatis简单集成

继续使用以简单的例子从头开始建spring boot web多模块项目&#xff08;一&#xff09;中的项目进行mybatis集成。 1、pom.xml文件中&#xff0c;增加相关的依赖包的引入&#xff0c;分别是mybatis-spring-boot-starter、lombok、mysql-connector-java 如下&#xff1a; <d…...

Golang | Leetcode Golang题解之第354题俄罗斯套娃信封问题

题目&#xff1a; 题解&#xff1a; func maxEnvelopes(envelopes [][]int) int {n : len(envelopes)if n 0 {return 0}sort.Slice(envelopes, func(i, j int) bool {a, b : envelopes[i], envelopes[j]return a[0] < b[0] || a[0] b[0] && a[1] > b[1]})f : …...

jmeter中添加ip欺骗

1、首先在本机电脑中通过配置文件创建添加ip的配置文件&#xff0c;先创建一个txt格式的&#xff0c;直接修改文件名以及后缀为ips.bat 2、编辑该ips.bat文件&#xff0c;在文件中输入如下内容&#xff0c;用于快速给本机添加ip地址&#xff0c;&#xff08;2&#xff0c;1&…...

WPF篇(19)-TabControl控件+TreeView树控件

TabControl控件 TabControl表示包含多个共享相同的空间在屏幕上的项的控件。它也是继承于Selector基类&#xff0c;所以TabControl也只支持单选操作。另外&#xff0c;TabControl的元素只能是TabItem&#xff0c;这个TabItem继承于HeaderedContentControl类&#xff0c;所以Ta…...

appium下载及安装

下载地址&#xff1a;https://github.com/appium/appium-desktop/releases 双击安装就可以...

XSS项目实战

目录 一、项目来源 二、实战操作 EASY 1 2 3 4 5 6 7 8 一、项目来源 XSS Game - Learning XSS Made Simple! | Created by PwnFunction 二、实战操作 EASY 1 1.Easy -1 2.题目要求及源码 Difficulty is Easy.Pop an alert(1337) on sandbox.pwnfunction.com.No …...

SD-WAN降低网络运维难度的关键技术解析

为什么说SD-WAN&#xff08;软件定义广域网&#xff09;大大降低了网络运维的复杂性&#xff0c;主要是因为它的智能路径选择、应用识别和链路质量监测这三个核心技术。这几项在SD-WAN中尤为重要的技术&#xff0c;它们共同作用&#xff0c;提升了整体网络性能&#xff0c;为网…...

【算法基础实验】图论-最小生成树-Prim的即时实现

理论知识 Prim算法是一种用于计算加权无向图的最小生成树&#xff08;MST, Minimum Spanning Tree&#xff09;的贪心算法。最小生成树是一个连通的无向图的子图&#xff0c;它包含所有的顶点且总权重最小。Prim算法从一个起始顶点开始&#xff0c;不断将权重最小的边加入生成…...

LLama 3 跨各种 GPU 类型的基准测试

2024 年 4 月 18 日&#xff0c;AI 社区对 Llama 3 70B 的发布表示欢迎&#xff0c;这是一款最先进的大型语言模型 &#xff08;LLM&#xff09;。该型号是 Llama 系列的下一代产品&#xff0c;支持广泛的用例。该模型 istelf 在广泛的行业平台上表现良好&#xff0c;并提供了新…...

FreeRTOS 快速入门(五)之信号量

目录 一、信号量的特性1、信号量跟队列的对比2、两种信号量的对比 二、信号量1、二值信号量1.1 二值信号量用于同步1.2 二值信号量用于互斥 2、计数信号量 三、信号量函数1、创建2、删除3、give/take 一、信号量的特性 信号量&#xff08;Semaphore&#xff09;是一种实现任务…...

centos 服务器之间实现免密登录

为了在CentOS服务器之间实现免密登录&#xff0c;你需要使用SSH的公钥认证机制 比如两台centos系统的服务器A 和服务器B 首先我们实现从A服务器可以免密登录到服务器B上 首先生成公钥和秘钥&#xff1a; ssh-keygen -t rsa 生成了公钥和秘钥之后&#xff1a; ssh-copy-id r…...

RabbitMq实现延迟队列功能

1、rabbitmq服务端打开延迟插件 &#xff08;超过 4294967295毫秒 ≈ 1193 小时 ≈ 49.7 天 这个时间会立即触发&#xff09; 注意&#xff1a;只有RabbitMQ 3.6.x以上才支持 在下载好之后&#xff0c;解压得到.ez结尾的插件包&#xff0c;将其复制到RabbitMQ安装目录下的plug…...

redis内存淘汰策略

1. redis内存淘汰策略 日常常用&#xff1a;allkeys-lru&#xff1a;在键空间中移除最近最少使用的key。1.1 为什么需要使用redis内存淘汰策略? 因为我们服务器中的内存是有限的,不会无限多,所以需要对一些不常用的key进行内存清理.1.2 redis内存淘汰策略有哪些? redis默认…...

实时洞察应用健康:使用Spring Boot集成Prometheus和Grafana

1. 添加Prometheus和Actuator依赖 在pom.xml中添加Spring Boot Actuator和Micrometer Prometheus依赖&#xff1a; <dependencies> <!--监控功能Actuator--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring…...

生信圆桌x生信豆芽菜:生物信息学新手的学习与成长平台

生信豆芽菜是一个专门为生物信息学初学者创建的学习与交流平台&#xff0c;致力于帮助新手们快速入门并掌握生信分析的基础知识与技能。随着生物信息学在科研中的重要性日益提升&#xff0c;越来越多的学生和研究人员开始接触这一领域。生信豆芽菜正是为了满足这些新手的需求&a…...

创客匠人标杆对话(上):她如何通过“特长+赛道”实现财富升级

老蒋创客圈第64期对话标杆直播连麦&#xff0c;本期我们邀请到【iAMU蒙特梭利翻转星球】平台创始人申晓慧老师。 为我们揭秘“如何挖掘人生首个百万&#xff0c;实现财富升级&#xff1f;”&#xff0c;深度分享如何提炼用户痛点&#xff0c;高效引流新用户&#xff1f;如何通…...

测试微信模版消息推送

进入“开发接口管理”--“公众平台测试账号”&#xff0c;无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息&#xff1a; 关注测试号&#xff1a;扫二维码关注测试号。 发送模版消息&#xff1a; import requests da…...

Java 语言特性(面试系列1)

一、面向对象编程 1. 封装&#xff08;Encapsulation&#xff09; 定义&#xff1a;将数据&#xff08;属性&#xff09;和操作数据的方法绑定在一起&#xff0c;通过访问控制符&#xff08;private、protected、public&#xff09;隐藏内部实现细节。示例&#xff1a; public …...

Python:操作 Excel 折叠

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件&#xff0c;常用于在两个集合之间进行数据转移&#xff0c;如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model&#xff1a;绑定右侧列表的值&…...

HBuilderX安装(uni-app和小程序开发)

下载HBuilderX 访问官方网站&#xff1a;https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本&#xff1a; Windows版&#xff08;推荐下载标准版&#xff09; Windows系统安装步骤 运行安装程序&#xff1a; 双击下载的.exe安装文件 如果出现安全提示&…...

12.找到字符串中所有字母异位词

&#x1f9e0; 题目解析 题目描述&#xff1a; 给定两个字符串 s 和 p&#xff0c;找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义&#xff1a; 若两个字符串包含的字符种类和出现次数完全相同&#xff0c;顺序无所谓&#xff0c;则互为…...

GitFlow 工作模式(详解)

今天再学项目的过程中遇到使用gitflow模式管理代码&#xff0c;因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存&#xff0c;无论是github还是gittee&#xff0c;都是一种基于git去保存代码的形式&#xff0c;这样保存代码…...

解析奥地利 XARION激光超声检测系统:无膜光学麦克风 + 无耦合剂的技术协同优势及多元应用

在工业制造领域&#xff0c;无损检测&#xff08;NDT)的精度与效率直接影响产品质量与生产安全。奥地利 XARION开发的激光超声精密检测系统&#xff0c;以非接触式光学麦克风技术为核心&#xff0c;打破传统检测瓶颈&#xff0c;为半导体、航空航天、汽车制造等行业提供了高灵敏…...

离线语音识别方案分析

随着人工智能技术的不断发展&#xff0c;语音识别技术也得到了广泛的应用&#xff0c;从智能家居到车载系统&#xff0c;语音识别正在改变我们与设备的交互方式。尤其是离线语音识别&#xff0c;由于其在没有网络连接的情况下仍然能提供稳定、准确的语音处理能力&#xff0c;广…...

在RK3588上搭建ROS1环境:创建节点与数据可视化实战指南

在RK3588上搭建ROS1环境:创建节点与数据可视化实战指南 背景介绍完整操作步骤1. 创建Docker容器环境2. 验证GUI显示功能3. 安装ROS Noetic4. 配置环境变量5. 创建ROS节点(小球运动模拟)6. 配置RVIZ默认视图7. 创建启动脚本8. 运行可视化系统效果展示与交互技术解析ROS节点通…...