@classmethod和@staticmethod的使用

classmethod和staticmehod的使用

classmethod和staticmethod都是Python中的修饰器,封装在类中,对类中的函数和子类进行修饰

@staticmethod修饰的方法可以不用传递参数

class Person(object):
def __init__(self, name, age):
self.name = name
self.age = age
@staticmethod
def func():
print("我可以写在类中,但是我不能调用此类的方法和属性")

@staticmethod是静态方法,可以在创建对象的时候向其中传递参数

class Person(object):
def __init__(self, name, age):
self.name = name
self.age = age
@staticmethod
def func():
print("我可以写在类中,但是我不能调用此类的方法和属性")
@staticmethod
def func2(name, age):
print('我在实例化的时候就可以传递参数了,但是不能创建对象,即返回值为None')
print('姓名:{},年龄:{}'.format(name, age))
def run(self):
print('我叫{},今年{}岁了'.format(self.name, self.age))
Tom = Person("Tom", 5)
Tom.run()
Person.func2("Jack", 4)
Tom.func()
我叫Tom,今年5岁了
我在实例化的时候就可以传递参数了,但是不能创建对象,即返回值为None
姓名:Jack,年龄:4
我可以写在类中,但是我不能调用此类的方法和属性

@classmethod如果传递参数第一个参数必须传递cls,指的是所在类的别城,但是其没有被实例化

class CatAndMouse(object):
num = 123
def __init__(self,name):
self.name=name
def run(self):
print(f'我叫{self.name},猫和老鼠真好看')
@classmethod
def func1(cls): # cls表示没有被实例化的对象本身
print('我可以访问CatAndMouse类中的属性',cls.num)
print(cls)
print('我也可以运行我可以访问CatAndMouse类中的函数')
cls('Jack').run()
Tom = CatAndMouse("Tom")
print(Tom.name)
Tom.func1()
# CatAndMouse.func1()
Tom
我可以访问CatAndMouse类中的属性 123
<class '__main__.CatAndMouse'>
我也可以运行我可以访问CatAndMouse类中的函数
我叫Jack,猫和老鼠真好看
posted @   性格如此w  阅读(84)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示