python是雙面向的,既可以面向函數(shù)編程,也可以面向?qū)ο缶幊?所謂面向函數(shù)就是單獨(dú)一個(gè).py文件,里面沒(méi)有類(lèi),全是一些函數(shù),調(diào)用的時(shí)候?qū)肽K,通過(guò)模塊名.函數(shù)名()即可調(diào)用,完全不需要類(lèi),那么你可能會(huì)問(wèn),那要類(lèi)還有什么毛用?類(lèi)就是用來(lái)面向?qū)ο缶幊汤?類(lèi)可以有自己的屬性,類(lèi)可以創(chuàng)建很多實(shí)例,每個(gè)實(shí)例可以有不同的屬性,這也就保存了很多私有的數(shù)據(jù),總之都有存在的必要.
面向?qū)ο蟪绦蛟O(shè)計(jì)中,類(lèi)方法和靜態(tài)方法是經(jīng)常用到的術(shù)語(yǔ),邏輯上將:類(lèi)方法只能由類(lèi)名調(diào)用,靜態(tài)方法可以由類(lèi)名或者對(duì)象名調(diào)用。在python語(yǔ)法中,類(lèi)有三種方法,分別是實(shí)例方法,靜態(tài)方法,類(lèi)方法
classFoo(object):
'''類(lèi)三種方法語(yǔ)法形式'''
#在類(lèi)中定義普通方法,在定義普通方法的時(shí)候,必須添加self
definstance_method(self):
print("是類(lèi){}的實(shí)例方法,只能被實(shí)例對(duì)象調(diào)用".format(Foo))
#在類(lèi)中定義靜態(tài)方法,在定義靜態(tài)方法的時(shí)候,不需要傳遞任何類(lèi)的東西
@staticmethod
defstatic_method():
print("是靜態(tài)方法")
#在類(lèi)中定義類(lèi)方法,在定義類(lèi)方法的時(shí)候,需要傳遞參數(shù)clscls即為類(lèi)本身
@classmethod
defclass_method(cls):
print("是類(lèi)方法")
foo=Foo()
foo.instance_method()
foo.class_method()
foo.static_method()
print("---------------")
Foo.static_method()
Foo.class_method()
可以看出:
實(shí)例方法只能被實(shí)例對(duì)象調(diào)用,靜態(tài)方法(由@staticmethod裝飾的方法)、類(lèi)方法(由@classmethod裝飾的方法),可以被類(lèi)或類(lèi)的實(shí)例對(duì)象調(diào)用。
實(shí)例方法,第一個(gè)參數(shù)必須要默認(rèn)傳實(shí)例對(duì)象,一般習(xí)慣用self。對(duì)象方法中有self參數(shù),類(lèi)方法有cls參數(shù),靜態(tài)方法是不需要這些附加參數(shù)(在c++中,是沒(méi)有類(lèi)這個(gè)概念)
靜態(tài)函數(shù)(@staticmethod):即靜態(tài)方法,靜態(tài)方法是一類(lèi)特殊的方法,有時(shí)候你可能需要填寫(xiě)一個(gè)屬于這個(gè)類(lèi)的方法,但是這些代碼完全不會(huì)使用到實(shí)例對(duì)象本身。它主要處理這個(gè)類(lèi)的邏輯關(guān)聯(lián),如驗(yàn)證數(shù)據(jù);而且對(duì)參數(shù)沒(méi)有要求。
類(lèi)方法(@classmethod):即類(lèi)方法,類(lèi)方法不是綁定到對(duì)象上,而是綁定在類(lèi)上的方法,它更關(guān)注于從類(lèi)中調(diào)用方法,而不是從實(shí)例中調(diào)用方法,如構(gòu)造重載;
成員函數(shù):實(shí)例的方法,只能通過(guò)實(shí)例進(jìn)行調(diào)用;第一個(gè)參數(shù)必須要默認(rèn)傳類(lèi),一般習(xí)慣用cls。
以上內(nèi)容為大家介紹了Python類(lèi)方法,靜態(tài)方法的定義,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。