classmethod和staticmethod的使用

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

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

class Person(object):
	def __init__(slef,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 func1():
        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("Jerry", 4)
Tom.func1()

在这里插入图片描述
@staticmethod也可以传入一个Callable, 也就是说 Class 也是可以的

class Person(object):
...

    @staticmethod
    class Men(object):
        def __init__(self):
            print('我是Person类中的Men类,来自staticmethod')

    def run(self):
        print('我叫{},今年{}岁了'.format(self.name, self.age))


...
Tom.func1()
Tom.Men()

在这里插入图片描述

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

class CatAndMouse(object):
    num = 123

    def __init__(self,name):
        self.name = name

    def run(self):
        print('我叫:{},猫和老鼠真好看'.format(self.name))
    @classmethod
    def func1(cls): #cls 表示没有被实例化的对象本身
        print('我可以访问CatAndMouse类中的属性',cls.num)
        print(cls)
        print('我也可以运行CatAndMouse中的函数')
        cls('Jerry').run()


Tom = CatAndMouse("Tom")
Tom.func1()
CatAndMouse.fun1() # 同上,可以不用实例化一个对象,就可以访问类中的方法

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值