当前位置: 首页 > 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;如何通…...

最少钱学习并构建大模型ollama-llama3 8B

学习大模型时可能面临一些困难&#xff0c;这些困难可能包括&#xff1a; 计算资源限制&#xff1a;训练大模型通常需要大量的计算资源&#xff0c;包括CPU、GPU等。如果设备资源有限&#xff0c;可能会导致训练时间长、效率低下或无法完成训练。 内存限制&#xff1a;大模型通…...

AVI视频损坏了怎么修复?轻松几步解决你的困扰

在数字化时代&#xff0c;视频已成为我们记录生活、分享经验和传递信息的重要方式。AVI作为一种常见的视频格式&#xff0c;因其无损质量的特点而受到广泛欢迎。然而&#xff0c;有时候我们可能会遇到AVI视频文件损坏的情况&#xff0c;导致无法正常播放。别担心&#xff0c;本…...

【C++】map、set基本用法

欢迎来到我的Blog&#xff0c;点击关注哦&#x1f495; 前言: C的STL已经学习很大一部分了&#xff0c;接下来介绍的是map set是c的是两种关联容器。 简单介绍 map set&#xff1a; 两者都使用红黑树作为底层数据结构来存储元素。map是一种键值对容器&#xff0c;其中每个键…...

模型 闭环原理

系列文章 分享 模型&#xff0c;了解更多&#x1f449; 模型_思维模型目录。反馈驱动&#xff0c;持续循环&#xff0c;缺陷亦被放大。 1 闭环原理的应用 1.1 闭环原理解读 AI自我训练&#xff0c;从人工智能变成人工智障 这里主要使用闭环原理来解释 AI 自我训练导致的问题。…...

3007. 价值和小于等于 K 的最大数字(24.8.21)

前言 感谢皇家笨阿宝的指导 题目 给你一个整数 k 和一个整数 x 。整数 num 的价值是它的二进制表示中在 x&#xff0c;2x&#xff0c;3x 等位置处设置位的数目&#xff08;从最低有效位开始&#xff09;。下面的表格包含了如何计算价值的例子。 XnumBinary RepresentationPri…...

微服务 - 分布式锁的实现与处理策略

作者&#xff1a;逍遥Sean 简介&#xff1a;一个主修Java的Web网站\游戏服务器后端开发者 主页&#xff1a;https://blog.csdn.net/Ureliable 觉得博主文章不错的话&#xff0c;可以三连支持一下~ 如有疑问和建议&#xff0c;请私信或评论留言&#xff01; 分布式锁的实现与处理…...

Catf1ag CTF Web(九)

前言 Catf1agCTF 是一个面向所有CTF&#xff08;Capture The Flag&#xff09;爱好者的综合训练平台&#xff0c;尤其适合新手学习和提升技能 。该平台由catf1ag团队打造&#xff0c;拥有超过200个原创题目&#xff0c;题目设计注重知识点的掌握&#xff0c;旨在帮助新手掌握C…...

QT QFileDialog 类

QFileDialog 类 QFileDialog 类 QFileDialog 是 Qt 库中的一个类&#xff0c;用于提供文件选择对话框&#xff0c; 允许用户选择文件或目录。QFileDialog 提供了多种静态方法和实例方法&#xff0c; 用于创建和配置文件对话框&#xff0c;并获取用户选择的文件或目录。 QObje…...

了解 K-Means 聚类的工作原理(详细指南)

一、说明 K-means 的目标是将一组观测值划分为 k 个聚类&#xff0c;每个观测值分配给均值&#xff08;聚类中心或质心&#xff09;最接近的聚类&#xff0c;从而充当该聚类的代表。 在本文中&#xff0c;我们将全面介绍 k 均值聚类&#xff08;最常用的聚类方法之一&#xff0…...

预警先行,弯道哨兵让行车更安全

预警先行&#xff0c;弯道哨兵让行车更安全”这句话深刻体现了现代交通安全理念中预防为主、科技赋能的重要性。在道路交通中&#xff0c;尤其是复杂多变的弯道区域&#xff0c;交通事故的发生率往往较高&#xff0c;因此&#xff0c;采取有效的预警措施和引入先进的交通辅助设…...