今天和大家一起交流一下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'
所以大家务必记住,对于静态方法的调用,需要传入对象本身
好了,今天跟大家分享到这里
如果有哪里理解错误的还望大神指点,谢谢