深入理解 Python 中的几种方法:实例方法、类方法、静态方法与特殊方法
前置阅读,了解什么是
类属性
、实例属性
,对于理解类方法
、实例方法
会有帮助:Python 中的类属性与实例属性详解
0、总体介绍
在 Python 中,方法(method) 是定义在类(class)内部的函数,它们为对象(object)和类提供行为和功能。
根据绑定方式和访问权限的不同,Python 中的方法主要可以分为四类:
- 实例方法(Instance Methods):最常用的方法类型,定义时第一个参数通常为
self
,用于访问和修改实例属性。 - 类方法(Class Methods):使用
@classmethod
装饰器,第一个参数为cls
,用于访问和修改类属性,常用于工厂方法。 - 静态方法(Static Methods):使用
@staticmethod
装饰器,不接收隐含的self
或cls
参数,常用作工具函数或与类概念相关但不依赖实例/类状态的函数。 - 特殊方法(Special Methods):也称为“魔术方法(dunder methods)”,形如
__init__
、__str__
、__add__
等,用于实现运算符重载、对象构造、表示和协议(如可迭代)等功能。
下面将依次详细介绍这几种方法的定义方式、使用场景和注意事项。
1、实例方法
1.1、定义与语法
实例方法是最常见的方法类型,它依赖于类的实例进行调用。
定义时,第一个参数通常命名为 self,代表当前实例本身。
class MyClass:def __init__(self, value):self.value = value # 实例属性def instance_method(self, increment):# 通过 self 访问实例属性return self.value + increment
调用方式如下:
obj = MyClass(10)
result = obj.instance_method(5) # 自动将 obj 作为 self 传入
print(result) # 输出:15
在调用 obj.instance_method(5)
时,Python 会自动将 obj
作为第一个参数传入方法中的 self
,等效于:MyClass.instance_method(obj, 5)
。
1.2、功能与用途
- 访问和修改实例状态:实例方法可以读写
self
上的属性,实现对象特有的行为。 - 封装逻辑:将与特定实例密切相关的逻辑放在实例方法中,符合“高内聚、低耦合”原则。
- 支持继承与重写:子类可以继承并覆盖父类的实例方法,并通过方法**重写(override)**实现多态。
示例:
class Animal:def speak(self):return "Some sound"class Dog(Animal):def speak(self):return "Woof!"a = Animal()
d = Dog()
print(a.speak()) # 输出:Some sound
print(d.speak()) # 输出:Woof!
1.3、注意事项
- 实例方法 必须定义
self
参数,否则方法将无法访问实例的属性和其他方法。 - 如果方法只与类级别的属性有关(即与具体实例无关),应考虑使用类方法或静态方法,避免误用实例方法而导致代码可读性下降。
示例错误用法:
class BadExample:count = 0def increase_count(self): # 错误:这里只使用了类属性,推荐用类方法BadExample.count += 1
推荐改法:
class BetterExample:count = 0@classmethoddef increase_count(cls): # 正确:与类属性相关,使用类方法更合适cls.count += 1
2、类方法
2.1、定义与语法
类方法是与类本身相关联的方法,而不是某个具体实例。定义类方法时,需要使用 @classmethod
装饰器,并将第一个参数命名为 cls
,代表类本身。
class MyClass:count = 0 # 类属性@classmethoddef increment_count(cls):cls.count += 1return cls.count
调用方式:
print(MyClass.increment_count()) # 输出:1
print(MyClass.increment_count()) # 输出:2
在调用 MyClass.increment_count()
时,Python 会自动将 MyClass
作为第一个参数传入 cls
。
2.2、功能与用途
- 访问和修改类状态:通过
cls
访问类属性或其他类方法,常用于管理类范围的共享状态。 - 工厂方法(Factory Method):使用类方法代替构造函数,根据传入参数创建并返回不同配置的实例。
示例:
class Person:species = "Homo sapiens"def __init__(self, name, age):self.name = nameself.age = age@classmethoddef from_birth_year(cls, name, birth_year):current_year = 2025age = current_year - birth_yearreturn cls(name, age)p = Person.from_birth_year("Alice", 2000)
print(p.name, p.age) # 输出:Alice 25
2.3、注意事项
- 类方法不能访问实例属性(即不能使用
self
),只能访问类级别的信息。 - 在继承体系中,类方法可以自动适配子类,因为
cls
指向调用它的实际类,这对于工厂方法非常重要。
3、静态方法
3.1、定义与语法
静态方法通过 @staticmethod
装饰器定义,不接收 self
或 cls
参数。它们只是放在类命名空间下的普通函数,不依赖类或实例的状态。
class MathUtils:@staticmethoddef add(a, b):return a + b
调用方式:
print(MathUtils.add(3, 5)) # 输出:8
静态方法既可以通过类名调用,也可以通过类实例调用,但它本质上就是一个与类逻辑相关的函数。
3.2、功能与用途
- 通用工具函数:与类有关,但不依赖类属性或实例属性的辅助功能。
- 逻辑归类:将逻辑上相关的函数放在类中,方便组织代码,避免污染全局命名空间。
示例:
class TemperatureConverter:@staticmethoddef celsius_to_fahrenheit(c):return c * 9 / 5 + 32@staticmethoddef fahrenheit_to_celsius(f):return (f - 32) * 5 / 9print(TemperatureConverter.celsius_to_fahrenheit(25)) # 输出:77.0
3.3、注意事项
- 静态方法不能访问实例属性(
self
)或类属性(cls
),它的独立性最强。 - 如果方法需要访问类或实例的数据,应使用类方法或实例方法,避免滥用静态方法导致封装性下降。
4、特殊方法(魔术方法)
4.1、定义与语法
特殊方法,又称“魔术方法(magic method)”或“dunder method”,是 Python 提供的一套以双下划线开头和结尾的特殊方法,用于实现对象的各种内置行为,比如构造、打印、运算符重载、容器协议等。
class Vector:def __init__(self, x, y):self.x = xself.y = ydef __add__(self, other): # 支持 + 运算符return Vector(self.x + other.x, self.y + other.y)def __repr__(self): # 打印友好return f"Vector({self.x}, {self.y})"
使用示例:
v1 = Vector(1, 2)
v2 = Vector(3, 4)
print(v1 + v2) # 输出:Vector(4, 6)
4.2、功能与用途
- 对象构造与销毁:如
__init__()
、__del__()
,用于创建和销毁对象。 - 运算符重载:如
__add__()
、__sub__()
等,使对象支持+
、-
等运算。 - 字符串表示:如
__str__()
和__repr__()
,分别用于用户友好输出和调试信息。 - 容器协议支持:如
__len__()
、__getitem__()
、__iter__()
,使对象支持len()
、索引、迭代等操作。
示例:
class CustomList:def __init__(self, items):self.items = itemsdef __len__(self):return len(self.items)def __getitem__(self, index):return self.items[index]my_list = CustomList([1, 2, 3])
print(len(my_list)) # 输出:3
print(my_list[1]) # 输出:2
4.3、注意事项
- 特殊方法一般不直接调用,应通过内置函数或操作符间接调用(如使用
len(obj)
而不是obj.__len__()
)。 - 合理地实现
__repr__
和__str__
有助于调试和日志记录。 - 特殊方法必须严格遵循语法和预期行为,否则可能导致兼容性问题或类型错误。
相关文章:
深入理解 Python 中的几种方法:实例方法、类方法、静态方法与特殊方法
前置阅读,了解什么是类属性、实例属性,对于理解类方法、实例方法会有帮助:Python 中的类属性与实例属性详解 0、总体介绍 在 Python 中,方法(method) 是定义在类(class)内部的函数&…...
游戏开发实战(二):Python复刻「崩坏星穹铁道」嗷呜嗷呜事务所---源码级解析该小游戏背后的算法与设计模式【纯原创】
文章目录 奇美拉和队列奇美拉被动技能多对多观察者关系实现自定义元类奇美拉基类 管理奇美拉的队列奇美拉队列类心得体会扩展 规则定义工作相关奇美拉相关 奇美拉属性 在本篇博文,我将介绍本项目的整体框架,以及“编码规则”,这些规则保证了本…...
Python实战:打造一个功能完整的单位转换器(长度/温度/货币)
📚 文章导读 在本文中,我将为大家介绍如何使用Python开发一个实用的单位转换器。这个项目不仅适合Python初学者练手,也能帮助你更好地理解Python的基础语法和函数设计。 🔍 主要特性 ✅ 支持多种长度单位互转(米、千…...
嵌入式学习笔记 D24 :系统编程之i/o操作
系统编程基本概念及一般组成文件的常见i/o操作 一、系统编程基本概念及一般组成 系统编程属于应用程序编程,即在操作系统运行成功的基础上执行程序。其一般包含以下四部分: 1)文件:存储在存储设备上的相关信息集合,是…...
利用朴素贝叶斯对UCI 的 mushroom 数据集进行分类
朴素贝叶斯(Naive Bayes)是一种基于贝叶斯定理的简单而有效的分类算法,特别适合处理文本分类和多类别分类问题。UCI的Mushroom数据集是一个经典的分类数据集,包含蘑菇的特征和类别(可食用或有毒)。 1. 数据…...
Index-AniSora模型论文速读:基于人工反馈的动漫视频生成
Aligning Anime Video Generation with Human Feedback 一、引言 论文开头指出,尽管视频生成模型不断涌现,但动漫视频生成面临动漫数据稀缺和运动模式异常的挑战,导致生成视频存在运动失真和闪烁伪影等问题,难以满足人类偏好。现…...
FineBI 和 Axure工具比较——数据分析VS原型设计
FineBI和Axure是两款定位截然不同的工具,分别服务于数据分析和原型设计领域。以下从核心功能、应用场景、操作门槛等维度进行对比分析: 一、核心功能对比 FineBI 作为商业智能(BI)工具,聚焦于数据整合、清洗、分析及可…...
跟踪AI峰会,给自己提出的两个问题。
踪红杉AI峰会全纪录:AI打开万亿美元市场,卖的不是工具,而是收益。 原文链接: 红杉AI峰会全记录:AI打开万亿美元市场,卖的不是工具,而是收益(全文)_腾讯新闻 自己的学习…...
分布式ID生成器:原理、对比与WorkerID实战
一、为什么需要分布式ID? 在微服务架构下,单机自增ID无法满足跨服务唯一性需求,且存在: • 单点瓶颈:数据库自增ID依赖单表写入 • 全局唯一性:跨服务生成可能重复 • 扩展性差:分库分表后ID规…...
AR 开启昆虫学习新视界,解锁奇妙微观宇宙
在传统昆虫学习中,课堂教学是主要方式,老师通过板书、PPT 传授知识,但学生被动接受,书本静态图片无法展现昆虫真实比例、立体形态,学生难以直观感受复杂身体结构。博物馆的昆虫标本也是学习途径,不过标本放…...
WPF技巧-常用的Converter集合(更新ing)
文章目录 [toc]🧩 示例 1:BooleanToVisibilityConverter🧩 示例 2:InvertedBooleanToVisibilityConverter🧩 示例 3:StringToColorConverter🧩 示例 4:StringToBrushConverter&#…...
PostGIS栅格数据类型解析【raster】
PostGIS 栅格数据类型解析:结构、转换与应用 一、栅格数据类型概述 在 PostGIS 中,raster 是用于存储和处理栅格数据的核心类型,支持从多种格式(如 JPEG、GeoTIFF、PNG、DEM)导入的数据。每个栅格由一个或多个波段&a…...
985,成立人工智能学院
5月17日,北京理工大学AI变革与科教创新论坛暨人工智能学院成立大会在中关村校区举行。 北京理工大学校长姜澜介绍了学校近年来高质量发展取得的成绩。他表示,北京理工大学对人工智能高度重视、提前布局,具备扎实基础。学校将通过“一零一一”…...
使用 ARCore 和 Kotlin 开发 Android 增强现实应用入门指南
环境准备 1. 工具与设备要求 Android Studio:Arctic Fox 或更高版本设备:支持 ARCore 的 Android 设备(查看支持列表)依赖库:// build.gradle (Module级) dependencies {implementation com.google.ar:core:1.35.0im…...
房贷利率计算前端小程序
利率计算前端小程序 视图效果展示如下: 在这里插入代码片 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0&qu…...
剧本杀小程序:指尖上的沉浸式推理宇宙
在推理热潮席卷社交圈的当下,你是否渴望随时随地开启一场烧脑又刺激的冒险?我们的剧本杀小程序,就是你掌心的“推理魔法盒”,一键解锁无限精彩! 海量剧本库,满足多元口味:小程序汇聚了从古风权…...
shp2pgsql 导入 Shp 到 PostGIS 空间数据库
前言 ❝ shp2pgsql是PostGIS自带的命令行工具,用于将Shapefile文件声称SQL脚本导入到PostGIS空间数据库。 1. 安装 PostGIS 通过Application Stack Builder或者下载单独的PostGIS包进行安装。而shp2pgsql则是与PostGIS工具集成在一起,无需单独下载。该命…...
什么是 ERP、MES、PLM,生产制造中如何应用
生产制造领域数字化转型加速背景下,ERP、MES、PLM 系统的应用成为企业提升竞争力的关键。然而,部分企业因对三者功能认知模糊、系统搭配不当、实施流程缺失,导致生产计划混乱、库存失衡、质量管控失效等问题频发。明晰系统功能定位与协同逻辑…...
Android Edge-to-Edge
Android Edge-to-Edge显示:开发者综合指南 一、什么是Android Edge-to-Edge Android Edge-to-Edge是一种先进的用户界面(UI)设计理念,旨在最大化利用设备的显示区域。它允许应用程序的内容延伸至屏幕的各个边缘,包…...
Java期末总复习 编程题(偏基础)
71. ①编写一个含 2 个属性的类,并为其设计有参构造方法,再设计一个用于显示属性值的方法。②编写该类的一个子类,除继承父类的 2 个属性外再增加一个属性,并创建有参构造方法对 3个属性初始化,重写显示属性的方法用于…...
进阶知识:自动化框架开发之有参的函数装饰器@wraps()和无参之间的对比
进阶知识:自动化框架开发之有参的函数装饰器wraps() 一、核心代码解析 1.1 有参装饰器结构 def func_3(argTrue): # 外层接收参数def inner_func(func): # 中间层接收被装饰函数wraps(func) # 保留元信息def wrap_func(*args, **kwargs): …...
es疑惑解读
好的,没问题。下面是我们对话中关于 Elasticsearch 数据库的知识点汇总,以问答对的形式呈现,希望能成为一个清晰的教程。 Elasticsearch 基础与 CRUD 操作 Q1: 我有 pymysql 的使用经验,想学习 Elasticsearch (ES) 的增删改查&am…...
Elasticsearch面试题带答案
Elasticsearch面试题带答案 Elasticsearch面试题及答案【最新版】Elasticsearch高级面试题大全(2025版),发现网上很多Elasticsearch面试题及答案整理都没有答案,所以花了很长时间搜集,本套Elasticsearch面试题大全,Elasticsearch面试题大汇总,有大量经典的Elasticsearch面…...
Linux 的 TCP 网络编程 -- 回显服务器,翻译服务器
目录 1. 相关函数介绍 1.1 listen() 1.2 accept() 1.3 connect() 2. TCP 回显服务器 2.1 Common.hpp 2.2 InetAddr.hpp 2.3 TcpClient.cc 2.4 TcpServer.hpp 2.5 TcpServer.cc 2.6 demo 测试 3. TCP 翻译服务器 3.1 demo 测试 1. 相关函数介绍 其中一些函数在之前…...
差动讯号(2):奇模与偶模
我们经常在探讨差动对时经常听到差模(Differential mode)与共模(Common mode),究竟什么是差模? 什么是共模? 这一切就要从奇模(Odd mode)与偶模(Even mode&am…...
口腔牙科小程序源码介绍
基于ThinkPHP、FastAdmin以及UniApp开发的口腔牙科小程序源码,专为口腔牙科行业设计,旨在提供一个便捷、高效的线上服务平台。 从技术层面看,这套源码结合了ThinkPHP的强大后端功能、FastAdmin的快速开发特性以及UniApp的跨平台优势…...
云计算与大数据进阶 | 27、存储系统如何突破容量天花板?可扩展架构的核心技术与实践—— 分布式、弹性扩展、高可用的底层逻辑(上)
数据中心里,存储系统是至关重要的组成部分。由于相关硬件组件与存储操作系统的多样性和复杂性,如何在保证存储稳定、安全、可靠的同时,实现灵活扩展和自服务,一直是困扰数据中心全面云化的难题。 简单来说,现在的难题…...
企业级物理服务器选型指南 - 网络架构优化篇
在分布式系统架构中,物理服务器的网络质量直接影响业务连续性。本文将通过真实场景演示如何选择符合业务特性的物理服务器。 一、网络拓扑设计原则 当企业需要覆盖多地域用户时,建议采用混合组网方案: # 网络质量检测脚本(Pytho…...
可视化图解算法42:寻找峰值
牛客网 面试笔试TOP101 | LeetCode 162. 寻找峰值 1. 题目 描述 给定一个长度为n的数组nums,请你找到峰值并返回其索引。数组可能包含多个峰值,在这种情况下,返回任何一个所在位置即可。 1.峰值元素是指其值严格大…...
java每日精进 5.20【MyBatis 联表分页查询】
1. MyBatis XML 实现分页查询 1.1 实现方式 MyBatis XML 是一种传统的 MyBatis 使用方式,通过在 XML 文件中编写 SQL 语句,并结合 Mapper 接口和 Service 层实现分页查询。分页需要手动编写两条 SQL 语句:一条查询分页数据列表,…...
瀚高安全版4.5.8/4.5.9字符串默认按字节存储导致数据无法写入(APP)
文章目录 环境文档用途详细信息 环境 系统平台:Linux x86-64 Red Hat Enterprise Linux 7 版本:4.5 文档用途 解决安全版4.5.8/4.5.9字符串默认使用字节存储导致插入时提示数据超长。 详细信息 使用sysdba用户执行,重载配置或重启数据库…...
python新手学习笔记①
本笔记是根据Bilibili里的【3小时超快速入门Python | 动画教学【2025新版】【自学Python教程】【零基础Python】【计算机二级Python】【Python期末速成】】 https://www.bilibili.com/video/BV1Jgf6YvE8e/这个视频合集制作的代码笔记! 1.字符串连接 运行结果 2.…...
用于管理共享内存的 C# 类 ShareMemory
可以在 Windows 和 Linux 上运行,利用了 .NET Core 的 System.IO.MemoryMappedFiles 库。这个类实现了共享内存的创建、打开、读取和写入功能。以下是对代码的一些分析和建议改进。 代码分析 初始化与打开共享内存: Init 方法用于创建新的共享内存段。OpenMem 方法…...
arcgispro双击打开没反应怎么办
不知道什么原因,突然就打不开了,网上关于arcgispro的教程和求助帖还比较少,参考了几个博主的分享,还是没解决 Arcpro——arcpro启动无反应_arcgispro正在初始化后没反应-CSDN博客 Arcgis Pro安装完成后启动失败的解决办法_arcgi…...
常见高速电路设计与信号完整性核心概念
一、传输线理论(Transmission Line Theory) 基本定义 当信号频率或边沿速率足够高时,互连线的长度与信号波长可比拟(通常为信号上升时间的1/6以上),此时需将互连视为传输线,而非理想导线。 临界…...
青少年编程与数学 02-019 Rust 编程基础 20课题、面向对象
青少年编程与数学 02-019 Rust 编程基础 20课题、面向对象 一、面向对象的编程特性(一)封装(Encapsulation)(二)多态(Polymorphism)(三)继承(Inhe…...
<uniapp><vuex><状态管理>在uniapp中,如何使用vuex实现数据共享与传递?
前言 本专栏是基于uniapp实现手机端各种小功能的程序,并且基于各种通讯协议如http、websocekt等,实现手机端作为客户端(或者是手持机、PDA等),与服务端进行数据通讯的实例开发。 发文平台 CSDN 环境配置 系统&…...
如何使用通义灵码辅助开发鸿蒙OS - AI编程助手提升效率
一、引言 鸿蒙 OS 是华为推出的一款面向全场景的分布式操作系统,其开发应用主要使用华为基于 IntelliJ IDEA 定制的 DevEco Studio。然而,DevEco Studio 的插件生态相对有限,为了提升开发效率和代码质量,我们可以借助通义灵码这一…...
解决git中断显示中文为八进制编码问题
git config --global core.quotepath false 命令用于配置 Git 如何处理非 ASCII 字符(如中文、日文、韩文等)的文件名显示 core.quotepath Git 的一个核心配置项,控制是否对非 ASCII 文件名进行转义(quote)处理。 f…...
宿州金博学校开展防震演练:夯实安全根基,守护校园平安
5月13日上午9点30分,金博学校原本宁静的校园被一阵急促的警报声打破,一场精心筹备、紧张有序的防震演练正式开启。本次演练意义重大,旨在强化全体师生的防震减灾意识,提高大家在地震突发时的应急反应与自我保护能力。 紧急避险&am…...
【鸿蒙开发】安全
应用隐私保护最佳实践 使用隐私声明获取用户同意 初次访问使用隐私声明弹窗,只有用户同意后才能开始正常使用。 减少应用的位置访问权限 使用模糊定位获取位置信息 位置权限申请方式 target API level申请位置权限申请结果位置的精确度小于9ohos.permission.L…...
企业级网络安全护盾:剖析高防IP原理与防护策略
在当今数字化时代,网络安全已成为企业不可忽视的关键课题。高防IP作为网络安全防护的重要手段之一,正因其出色的防御能力和应用灵活性受到广泛关注。本文将深入解析高防IP的原理,包括流量清洗、防御策略、节点分布等技术要点,并通…...
智能事件分析边缘服务器:交通管理与安全监测的利器
在当今交通管理和安全监测的领域中,智能化、高效化的设备需求日益增长。智能事件分析边缘服务器凭借其卓越的性能和丰富的功能,成为了该领域的佼佼者。 一、产品概述 智能事件分析边缘服务器是一款采用嵌入式 Linux 操作系统的边缘事件分析终端。它具有…...
Gin--Blog项目-flags文件解析
flags/enter.go文件解析 package flagsimport ("flag""os" )type Options struct {File stringDB boolVersion bool }var FlagOptions new(Options)func Parse() {flag.StringVar(&FlagOptions.File, "f", "settings.yaml&qu…...
JVM的面试相关问题
面试中的相关问题主要是三块 1.JVM 内存区域划分 2.JVM 的类加载机制 3.JVM 的垃圾回收机制 JVM Java虚拟机 VM Virtual Machine 虚拟机,用 软件 来 模拟 硬件 传统意义上的"虚拟机" 更多指的是 VMWare, Virtual Box, Hyper-V, KVM(构造出虚拟的电脑,甚至可以…...
Linux(3)——基础开发工具
一、软件包管理器——yum 1.Linux下安装程序的方式 在Linux环境下安装软件的方式有以下几个方式: 1)源码安装,直接下载源代码,让它自行编译运行形成可执行程序。 2)软件包安装,下载rpm安装包࿰…...
HarmonyOS5云服务技术分享--ArkTS调用函数
✨【HarmonyOS实战指南】手把手教你用ArkTS玩转云函数文件获取✨ 大家好呀今天我们来聊聊如何通过HarmonyOS的ArkTS语言实现云函数文件获取功能。整个过程就像搭积木一样有趣,保证小白也能轻松上手!(文末有完整代码模板哦) &…...
2025年AI搜索引擎发展洞察:技术革新与市场变革
引言:AI搜索的崛起与市场格局重塑 2024-2025年,AI搜索市场迎来了前所未有的变革期。随着DeepSeek-R1等先进大语言模型的推出,传统搜索引擎、AI原生搜索平台以及各类内容平台纷纷加速智能化转型,推动搜索技术从基础信息检索向深度…...
基于开源链动2+1模式AI智能名片S2B2C商城小程序的社群构建与新型消费迎合策略研究
摘要:随着个性化与小众化消费的崛起,消费者消费心理和模式发生巨大变化,社群构建对商家迎合新型消费特点、融入市场经济发展至关重要。开源链动21模式AI智能名片S2B2C商城小程序的出现,为社群构建提供了创新工具。本文探讨该小程序…...
leetcode 旋转数组 java
本来想用栈或者队列来解决,发现一直报k>nums.length的错。 将原数组下标为 i 的元素放至新数组下标为 (ik)modn 的位置,最后将新数组拷贝至原数组即可。 class Solution {public void rotate(int[] nums, int k) {// Stack<Integer> stack n…...