python中的定义类方法有三种形式
-
普通方法
-
类方法(@classmethod)
-
静态方法(@staticmethod)
普通方法
创建普通的方法的方式有两种(class A() & class B()).
class A():
def __init__(self, name, age):
self.name = name
self.age = age
def get_name(self):
print('my name is', self.name)
def get_age(self):
print(f'i am {self.age} years old')
class B():
def get_name(self, name):
print('my name is', name)
def get_age(self, age):
print(f'i am {age} years old')
if __name__ == '__main__':
a = A('tom',19)
a.get_name() # my name is tom
a.get_age() # i am 19 years old
b = B()
b.get_name('tom') # my name is tom
b.get_age(19) # i am 19 years old
class A() 中, __init__()
是一个特殊的方法,相当于对A进行初始化,__init__
中的self是对象A本身,name和age是它们的形参。
每次调用方法之前需要对类进行实例化
类方法
@classmethod不需要self来表示自身了,而是用了cls来代替。
此时不用再进行实例化了。直接 类名.函数名 进行调用。
#Python学习交流群:725638078
class C():
@classmethod
def get_name(cls, name):
print(cls) # <class '__main__.C'>
print('my name is %s' % name)
@classmethod
def get_age(cls, age):
print(f'i am %s years old' % age)
if __name__ == '__main__':
C.get_name('tom') # my name is tom
C.get_age(19) # i am 19 years old
静态方法
@staticmethod也是通过 类名.函数名 的方式进行调用
静态方法不需要表示自身对象的self或者cls作为参数,跟直接使用函数是一样的。
class D():
@staticmethod
def get_name(name):
print('my name is %s' % name)
@staticmethod
def get_age(age):
print(f'i am %s years old' % age)
if __name__ == '__main__':
D.get_name('tom') # my name is tom
D.get_age(19) # i am 19 years old
总结
@staticmethod 与 @classmethod在Python中称为 装饰器,
用来修饰函数,相当于添加一个额外的功能,比如不再像普通函数那样进行实例化。
通过使用装饰器可以让代码更加整洁,易读。用了修饰器之后,也可以进行实例化之后再调用,但是就显得多此一举了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
2019-11-23 python经典算法题:无重复字符的最长子串