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

【Linux】C语言执行shell指令

在C语言中执行Shell指令 在C语言中&#xff0c;有几种方法可以执行Shell指令&#xff1a; 1. 使用system()函数 这是最简单的方法&#xff0c;包含在stdlib.h头文件中&#xff1a; #include <stdlib.h>int main() {system("ls -l"); // 执行ls -l命令retu…...

2.Vue编写一个app

1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...

生成 Git SSH 证书

&#x1f511; 1. ​​生成 SSH 密钥对​​ 在终端&#xff08;Windows 使用 Git Bash&#xff0c;Mac/Linux 使用 Terminal&#xff09;执行命令&#xff1a; ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" ​​参数说明​​&#xff1a; -t rsa&#x…...

Qt Http Server模块功能及架构

Qt Http Server 是 Qt 6.0 中引入的一个新模块&#xff0c;它提供了一个轻量级的 HTTP 服务器实现&#xff0c;主要用于构建基于 HTTP 的应用程序和服务。 功能介绍&#xff1a; 主要功能 HTTP服务器功能&#xff1a; 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...

Linux云原生安全:零信任架构与机密计算

Linux云原生安全&#xff1a;零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言&#xff1a;云原生安全的范式革命 随着云原生技术的普及&#xff0c;安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测&#xff0c;到2025年&#xff0c;零信任架构将成为超…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(一)

宇树机器人多姿态起立控制强化学习框架论文解析 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架&#xff08;一&#xff09; 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化…...

Rust 异步编程

Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控&#xff0c;故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令&#xff1a;jps [options] [hostid] 功能&#xff1a;本地虚拟机进程显示进程ID&#xff08;与ps相同&#xff09;&#xff0c;可同时显示主类&#x…...

基于matlab策略迭代和值迭代法的动态规划

经典的基于策略迭代和值迭代法的动态规划matlab代码&#xff0c;实现机器人的最优运输 Dynamic-Programming-master/Environment.pdf , 104724 Dynamic-Programming-master/README.md , 506 Dynamic-Programming-master/generalizedPolicyIteration.m , 1970 Dynamic-Programm…...

在QWebEngineView上实现鼠标、触摸等事件捕获的解决方案

这个问题我看其他博主也写了&#xff0c;要么要会员、要么写的乱七八糟。这里我整理一下&#xff0c;把问题说清楚并且给出代码&#xff0c;拿去用就行&#xff0c;照着葫芦画瓢。 问题 在继承QWebEngineView后&#xff0c;重写mousePressEvent或event函数无法捕获鼠标按下事…...