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 
    print(d.run())
TypeError: run() missing 1 required positional argument: 'self'

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

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

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

你可能感兴趣的:(python基础)