一般情况,要使用某个类的方法,需要先实例化一个对象再调用方法。
而使用@staticmethod或@classmethod,就可以不需要实例化,直接类名.方法名()来调用。
既然@staticmethod和@classmethod都可以直接类名.方法名()来调用,那他们有什么区别呢
从它们的使用上来看,
-
@staticmethod 不需要表示自身对象的self和自身类的cls参数,就跟使用函数一样。
-
@classmethod 也不需要self参数,但第一个参数需要是表示自身类的cls参数。
-
@classmethod 是一个函数修饰符,它表示接下来的是一个类方法,而对于平常我们见到的则叫做实例方法。 类方法的第一个参数cls,而实例方法的第一个参数是self,表示该类的一个实例。
-
普通对象方法至少需要一个self参数,代表类对象实例
-
类方法有类变量cls传入,从而可以用cls做一些相关的处理。并且有子类继承时,调用该类方法时,传入的类变量cls是子类,而非父类。 对于类方法,可以通过类来调用,就像Test.foo()
如果在@staticmethod中要调用到这个类的一些属性方法,只能直接类名.属性名或类名.方法名。
代码示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
#!/usr/local/python3/bin/python3 class Door( object ):
a = 1
def __init__( self ,num,status):
self .num = num
self .status = status
def open ( self ):
self .var = 0
self .status = 'open'
def close( self ):
self .status = 'closed'
def __test( self ):
print ( '__test' )
@ classmethod
def test( cls ):
print ( "class test" )
#不需要self参数,但第一个参数需要是表示自身类的cls参数。 print ( cls .a)
@ staticmethod
def test2():
print ( "static test2" )
#不需要自身对象参数,直接使用类名+类变量调用 print (Door.a)
Door.test() d1 = Door( 1 , "closed" )
d1.test() #通过类名调用和通过实例调用 d2 = Door( 2 , "closed" )
Door.test2() d2.test2() |
输出结果:
本文转自qw87112 51CTO博客,原文链接:http://blog.51cto.com/tchuairen/1684201