python中类共有三类方法:普通方法,类方法,静态方法,具体解释如下:
注释1表示的是静态方法,需要用@staticmethod生命,并且不需要self参数。
注释2表示的是类方法,需要用@classmethod生命,参数为'cls',表示调用时传递类对象而非实例对象,这个过程由解释器自动完成。
注释3、4表示的是类中的普通函数,有‘self’参数,仅能由实例对象调用,调用时传递的参数是实例本身,同样由解释器自动完成。
其中实例对象可调用所有三种方法,而类对象不能调用普通方法。
静态方法与类方法对类的数据属性的修改是永久的,而普通方法不能修改类的数据属性,函数3中self.number += 3 创建了一个实例对象number,并不修改Tool.number。
# -*- coding: utf-8 -*-
"test clasaMethod and staticMethod"
class Tools(object):
number = 0
innum = 10
def __init__(self):
print "tools class"
@staticmethod
def getStaticNumber(): # 1
Tools.number += 1
return Tools.number + Tools.innum
@classmethod
def getClassNumber(cls): # 2
cls.number += 2
return cls.number
def getNumber(self): # 3
self.number2 = 0
self.number += 3
return self.number
def another(self): #4
print self.number
print self.number2
下面解释一下实例对象的数据属性,见如下调用过程:
>>> t = Tools()
tools class
>>> t.another () # 调用出错,此时实例“t”中没有数据属性“number2”
0
Traceback (most recent call last):
File "<pyshell#10>", line 1, in <module>
t.another ()
File "<pyshell#8>", line 25, in another
print self.number2
AttributeError: 'Tools' object has no attribute 'number2'
>>> dir(t) # 用dir(t)查看t的属性中确实没有number2
['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'another', 'getClassNumber', 'getNumber', 'getStaticNumber',<span style="color:#ff0000;"> <span style="color:#ff0000;">'innum', 'number'</span>]</span>
>>> t.getNumber() # 调用成功,getNnmber()函数中初始化了number2
3
>>> dir(t) #用dir(t)查看,发现t中此时已经存在了数据属性number2
['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'another', 'getClassNumber', 'getNumber', 'getStaticNumber', <span style="background-color: rgb(255, 102, 102);">'<span style="color:#ff0000;">innum', 'number', 'number2'</span>]</span>
>>> t.another() #调用成功
3
0
从上面的过程可以看到,除了__init__()方法外,也可以在别的普通类函数中创建实例的数据属性,但在创建该属性的函数未被调用前,该属性不可用。