当前位置: 代码迷 >> 综合 >> self,cls 与 staticmethod,classmethod
  详细解决方案

self,cls 与 staticmethod,classmethod

热度:94   发布时间:2024-01-11 00:59:21.0

一、总体说明

Python类的方法有三种(self和cls都可以用别的单词代替):

  • 一是通过def定义的 ,  普通的一般的,需要至少传递一个参数,一般用self,这样的方法必须通过一个类的实例去访问,类似于c++中通过对象去访问;
  • 二是在def前面加上@classmethod,这种类方法的一个特点就是可以通过类名去调用,但是也必须传递一个参数,一般用cls表示class,表示可以通过类直接调用;
  • 三是在def前面加上@staticmethod,这种类方法是静态的类方法,类似于c++的静态函数,他的一个特点是参数可以为空,同样支持类名和对象两种调用方式

普通的方法,第一个参数需要是self,它表示一个具体的实例本身。
如果用了staticmethod,那么就可以无视这个self,而将这个方法当成一个普通的函数使用。
而对于classmethod,它的第一个参数不是self,是cls,它表示这个类本身。

三个方法调用形式的区别:

实例方法(普通方法)——————————————————————随着实例属性的改变而改变

类方法(无论是类调用还是实例调用)——————————————都是类属性的值,不随实例属性的变化而变化

静态方法—————————————————————————不可以访问类属性,故直接输出传入方法的值

 

栗子:

>>> class A(object):def foo1(self):print("Hello",self)@staticmethoddef foo2():print("hello")@classmethoddef foo3(cls):print("hello",cls)>>> a = A()
>>> a.foo1()          #最常见的调用方式,但与下面的方式相同
Hello <__main__.A object at 0x9f6abec>>>> A.foo1(a)         #这里传入实例a,相当于普通方法的self
Hello <__main__.A object at 0x9f6abec>>>> A.foo2()          #这里,由于静态方法没有参数,故可以不传东西
hello>>> A.foo3()          #这里,由于是类方法,因此,它的第一个参数为类本身。
hello <class '__main__.A'>>>> A                 #可以看到,直接输入A,与上面那种调用返回同样的信息。
<class '__main__.A'>

 

二、深入理解

self,cls不是关键字

栗子:

class A:member = "this is a test."def __init__(self):pass@classmethoddef Print1(cls):print("print 1: ", cls.member)def Print2(self):print("print 2: ", self.member)@classmethoddef Print3(paraTest):print("print 3: ", paraTest.member)a = A()A.Print1()  # 相当于Print1(A)
a.Print2()  # 相当于Print2(a), 请注意@classmethod
A.Print3()

result:

print 1:  this is a test.
print 2:  this is a test.
print 3:  this is a test.

可以看出来,Python在通过“.”调用成员函数的时候,会将 “ . ” 前面的东西当作函数的第一个参数调用。

而且Pyhon并不关心我们把类的成员函数的第一个参数的名称是什么,我们可以用任意的名称,可以看Print3的定义就知道了。

 

|-------------------------------------------------scrat-----------------------------------------------------------|