@staticmethod 靜態(tài)方法只是名義上歸屬類管理,但是 不能使用類變量和實例變量,是類的工具包
按需策劃可以根據(jù)自己的需求進行定制,網(wǎng)站設計制作、成都網(wǎng)站建設構思過程中功能建設理應排到主要部位公司網(wǎng)站設計制作、成都網(wǎng)站建設的運用實際效果公司網(wǎng)站制作網(wǎng)站建立與制做的實際意義
放在函數(shù)前(該函數(shù)不傳入self或者cls),所以不能訪問類屬性和實例屬性
在學習python代碼時,看到有的類的方法中第一參數(shù)是cls,有的是self,經(jīng)過了解得知,python并沒有對類中方法的第一個參數(shù)名字做限制,可以是self,也可以是cls,不過根據(jù)人們的慣用用法,self一般是在實例方法中使用,而cls則一般在類方法中使用,在靜態(tài)方法中則不需要使用一個默認參數(shù)。在下面的代碼中,InstanceMethod類的方法中,第一個參數(shù)是默認的self,在這里可以把self換成任何名字來表示,不會有任何影響。在類調(diào)用的時候,需要滿足參數(shù)的個數(shù)要求(參數(shù)中含有*args是例外),例如13行中,類調(diào)用沒有參數(shù)的時候,會提示錯誤。同樣,實例方法的參數(shù)個數(shù)也應該滿足要求,例如16行中也會報錯。實例方法的一個主要特點就是需要綁定到一個對象上,python解析器會自動把實例自身傳遞給方法,如14行所示,而直接使用InstanceMethod.f1()調(diào)用方法是不行的。
12345678910111213
class InstanceMethod(object): def __init__(self, a): self.a = a def f1(self): print 'This is {0}.'.format(self) def f2(self, a): print 'Value:{0}'.format(a)if __name__ == '__main__': # im = InstanceMethod() im = InstanceMethod('233') im.f1() # im.f2() im.f2(233)
靜態(tài)方法和類方法都需要使用修飾器,分別使用的是staticmethod和classmethod。靜態(tài)方法是和類沒有關系的,我覺得就是包裝在類中的一般方法,如下例子中,調(diào)用靜態(tài)方法使用實例和不使用實例都是可以的。類方法中,默認的第一個參數(shù)使用的是cls,類方法也可以不需要實例而直接使用類調(diào)用。對于這三種不同的方法,使用方法如下例所示。那么問題來了,既然有了實例方法,類方法和靜態(tài)方法與之相比又有什么好處呢?
在類方法中,不管是使用實例還是類調(diào)用方法,都會把類作為第一個參數(shù)傳遞進來,這個參數(shù)就是類本身。如果繼承了這個使用類方法的類,該類的所有子類都會擁有了這個方法,并且這個方法會自動指向子類本身,這個特性在工廠函數(shù)中是非常有用的。靜態(tài)方法是和類與實例都沒有關系的,完全可以使用一般方法代替,但是使用靜態(tài)方法可以更好的組織代碼,防止代碼變大后變得比較混亂。類方法是可以替代靜態(tài)方法的。靜態(tài)方法不能在繼承中修改。
123456789101112131415161718
class test(object): def instance_method(self): print 'This is {0}'.format(self) @staticmethod def static_method(): print 'This is static method.' @classmethod def class_method(cls): print 'This is {0}'.format(cls)if __name__ == '__main__': a = test() a.instance_method() a.static_method() a.class_method() print '----------------------------------------' # test.instance_method() test.static_method() test.class_method()
在類里面定義的函數(shù)就是方法,類方法需要@ classmethod 修飾并且有個隱藏參數(shù) cls,實例方法必須有個參數(shù) self, 靜態(tài)方法必須有 @staticmethod修飾,類和實例都可以訪問靜態(tài)方法,實例可以訪問實例方法也可以訪問類方法
類可以訪問類方法也可以訪問實例方法,訪問實例方法必須要帶參數(shù) self, 可以理解為類其實也是一個實例,類訪問實例方法不帶參數(shù)會報錯的.類本身可以訪問函數(shù),實例卻不行.
Python使用靜態(tài)方法類似函數(shù)工具使用,一般盡量少用靜態(tài)方法。
Python的靜態(tài)方法和類成員方法都可以被類或?qū)嵗L問,兩者概念不容易理清,但還是有區(qū)別的:
1)靜態(tài)方法無需傳入self參數(shù),類成員方法需傳入代表本類的cls參數(shù);
2)從第1條,靜態(tài)方法是無法訪問實例變量的,而類成員方法也同樣無法訪問實例變量,但可以訪問類變量;
3)靜態(tài)方法有點像函數(shù)工具庫的作用,而類成員方法則更接近類似Java面向?qū)ο蟾拍钪械撵o態(tài)方法。
python的類里用@staticmethod的是靜態(tài)方法,@classmethod的是類方法,如下
class?Person(object):
person_list?=?[]
def?__init__(self,?name,?age):
self.name?=?name
self.age?=?age
self.person_list.append(self)
@classmethod
def?one_year_later(cls):
for?p?in?cls.person_list:
p.age?+=?1
@staticmethod
def?born_one_boby(name):
return?Person(name,?0)
def?__repr__(self):
return?'Person?name:%s,?age:%s'?%?(self.name,?self.age)
if?__name__?==?'__main__':
petter?=??Person('Petter',23)
merry?=?Person('Merry',21)
print(petter)?#?Person?name:Petter,?age:23
print(merry)??#??Person?name:Merry,?age:21
Person.one_year_later()
print(petter)??#??Person?name:Petter,?age:24
print(merry)??#??Person?name:Merry,?age:22
baby?=?merry.born_one_boby('Tom')
print(Person.person_list)?#??[Person?name:Petter,?age:24,?Person?name:Merry,?age:22,?Person?name:Tom,?age:0]
python函數(shù)實現(xiàn)static變量具體如下:
def ask_ok(prompt, retries=4, complaint='Yes or no, please!'):
while True:
ok = raw_input(prompt)
if ok in ('y', 'ye', 'yes'): return True
if ok in ('n', 'no', 'nop', 'nope'): return False
retries = retries - 1
if retries 0: raise IOError, 'refusenik user'
print complaint
Python函數(shù)默認值的使用可以在函數(shù)調(diào)用時寫代碼提供方便,很多時候我們只要使用默認值就可以了。 所以函數(shù)默認值在python中用到的很多,尤其是在類中間,類的初始化函數(shù)中一幫都會用到默認值。 使用類時能夠方便的創(chuàng)建類,而不需要傳遞一堆參數(shù)。
只要在函數(shù)參數(shù)名后面加上 ”=defalut_value”,函數(shù)默認值就定義好了。有一個地方需要注意的是,有默認值的參數(shù)必須在函數(shù)參數(shù)列表的最后,不允許將沒有默認值的參數(shù)放在有默認值的參數(shù)后,因為如果你那樣定義的話,解釋器將不知道如何去傳遞參數(shù)。