python大作战之静态方法@staticmethod和类方法@classmethod

今天和大家一起交流一下python中的另外两个装饰器,静态方法@staticmethod和类方法@classmethod

首先我们来讲一下类方法@classmethod,我们先来上一段代码:

class Dog(object):
    name='jack'
    def __init__(self,name):
        self.name=name
    @classmethod
    def run(self):
        return self.name
d=Dog('Tom')
print(d.run())
输出:jack

从代码中我们来分析下,name='jak'定义在了类中,称为类变量,同时我们在初始化的时候也设置了实例变量name,所以当我们在实例化的时候,按照未装饰前,这个name的返回值应该是Tom,但是当我们加了类方法@classmethod后,这个run方法只和类有关,和实例化后的对象无关,这个我们必须要认清,从下面的代码可以更清晰的认清

print(Dog.run())
输出:Jack

代码中直接用类名去调用,输出为类变量的值,所以无论是实例去调用run,还是类名去调用run,被装饰后的run方法都只跟类有关

类方法讲解完之后,我们来交流一下静态方法@staticmethod

让我们也从一段代码中来直观的看下是怎么处理的

class Dog(object):
    name='Jack'
    def __init__(self,name):
        self.name=name
    @staticmethod
    def run(self):
        return self.name
    @staticmethod
    def walk(self,name):
        return self.name
d=Dog('tom')
print(d.run(d))
print(d.walk(d,'kitty'))
输出:tom
输出:tom

从上述代码中可以看出静态方法跟类无关,但是跟实例(对象)有关,同时静态方法的实现方式必须传入对象,就是这么规定的,如果没传入对象,会报如下的错误:

Traceback (most recent call last):
  File "E:/fjh/python/静态方法.py", line 22, in <module>
    print(d.run())
TypeError: run() missing 1 required positional argument: 'self'

所以大家务必记住,对于静态方法的调用,需要传入对象本身

好了,今天跟大家分享到这里

如果有哪里理解错误的还望大神指点,谢谢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值