在python中使用@classmethod有什么用?何时使用?

时间:2019-01-19 04:31:51

标签: python decorator python-decorators

我从未使用过@classmethod,我不认为有任何示例可以使用它,我知道它是如何工作的,但是我不知道何时该使用它作为例子。

class Example:
    def __init__(self,param1,param2):
        self.param1 = param1
        self.param2 = param2
    @classmethod
    def my_method(cls,param1,param2):
        return cls(param1,param2)

example = Example.my_method(1,2)
print(example)

输出:

<__main__.Example object at 0x02EC57D0>

但是为什么不这样做呢?

class Example:
    def __init__(self,param1,param2):
        self.param1 = param1
        self.param2 = param2

    def my_method(self,param1,param2):
        return Example(param1,param2)

example = Example(1,2)
method = example.my_method(3,4)
print(method)

输出:

<__main__.Example object at 0x02EC57D0>

这是相同的结果,但是当我可以使用classmethod时却没想到

1 个答案:

答案 0 :(得分:1)

python中有3种方法:

  • 实例方法
  • 类方法
  • 静态方法
class Person():
    species='homo_sapiens' # This is class variable
    def __init__(self, name, age):
        self.name = name # This is instance variable
        self.age = age

    def show(self):
        print('Name: {}, age: {}.'.format(self.name, date.today().year - self.age))

    @classmethod
    def create_with_birth_year(cls, name, birth_year):
        return cls(name, date.today().year - birth_year)

    @classmethod
    def print_species(cls):
        print('species: {}'.format(cls.species))

    @staticmethod
    def get_birth_year(age):
        return date.today().year - age


class Teacher(Person):
    pass

1)实例方法( show )需要一个实例,并且必须使用 self 作为第一个参数。它可以通过 self 访问实例并影响实例的状态。

2)类方法( create_with_birth_year print_species )不需要实例,并使用 cls 访问类并影响类的状态。我们可以使用 @classmethod 来建立工厂,例如:

navy = Person.create_with_birth_year('Navy Cheng', 1989)
navy.show()

该工厂可以被继承

zhang = Teacher.create_with_birth_year('zhang', 1980)
print(type(zhang))

和类方法可以用来访问类变量:

Person.print_species()

3)静态方法( get_birth_year )不需要特殊参数( self cls ),并且可以更改类或实例的任何状态。它可以使有关某个类的一些辅助功能失效。