python中的實(shí)例方法、靜態(tài)方法、類方法、類變量和實(shí)例變量淺析
注:使用的是Python2.7。
一、實(shí)例方法
實(shí)例方法就是類的實(shí)例能夠使用的方法。如下:
class Foo:
def __init__(self, name):
self.name = name
def hi(self):
print self.name
if __name__ == '__main__':
foo01 = Foo('letian')
foo01.hi()
print type(Foo)
print type(foo01)
print id(foo01)
print id(Foo)
運(yùn)行結(jié)果為:
letian
<type 'classobj'>
<type 'instance'>
40124704
31323448[code]
可以看到,F(xiàn)oo的type為classobj(類對(duì)象,python中定義的類本身也是對(duì)象),foo01的type為instance(實(shí)例)。而hi()是實(shí)例方法,所以foo01.hi()會(huì)輸出'letian'。實(shí)例方法的第一個(gè)參數(shù)默認(rèn)為self,代指實(shí)例。self不是一個(gè)關(guān)鍵字,而是約定的寫法。init()是生成實(shí)例時(shí)默認(rèn)調(diào)用的實(shí)例方法。將Foo的定義改為以下形式:
[code]class Foo:
def __init__(this, name):
this.name = name
def hi(here):
print here.name
運(yùn)行依然正確。 內(nèi)置函數(shù)id用來查看對(duì)象的標(biāo)識(shí)符,下面是其doc內(nèi)容:
>>> print id.__doc__
id(object) -> integer
Return the identity of an object. This is guaranteed to be unique among
simultaneously existing objects. (Hint: it's the object's memory address.)
二、靜態(tài)方法
靜態(tài)方法是一種普通函數(shù),就位于類定義的命名空間中,它不會(huì)對(duì)任何實(shí)例類型進(jìn)行操作。使用裝飾器@staticmethod定義靜態(tài)方法。類對(duì)象和實(shí)例都可以調(diào)用靜態(tài)方法:
class Foo:
def __init__(self, name):
self.name = name
def hi(self):
print self.name
@staticmethod
def add(a, b):
print a + b
if __name__ == '__main__':
foo01 = Foo('letian')
foo01.hi()
foo01.add(1,2)
Foo.add(1, 2)
運(yùn)行結(jié)果如下:
letian
3
3
注意,很多編程語言不允許實(shí)例調(diào)用靜態(tài)方法。
三、類方法
類方法是將類本身作為對(duì)象進(jìn)行操作的方法。類方法使用@classmethod裝飾器定義,其第一個(gè)參數(shù)是類,約定寫為cls。類對(duì)象和實(shí)例都可以調(diào)用類方法:
class Foo:
name = 'letian '
@classmethod
def hi(cls, x):
print cls.name * x
if __name__ == '__main__':
foo01 = Foo()
foo01.hi(2)
Foo.hi(3)
運(yùn)行結(jié)果如下:
letian letian
letian letian letian
注意,很多其他的編程語言不允許實(shí)例調(diào)用類方法。
四、super
super用來執(zhí)行父類中的函數(shù),例如:
class Foo(object):
def hi(self):
print 'hi,Foo'
class Foo2(Foo):
def hi(self):
super(Foo2, self).hi()
if __name__ == '__main__':
foo2 = Foo2()
foo2.hi()
運(yùn)行結(jié)果:
hi,Foo
注意,F(xiàn)oo類必須繼承某個(gè)類(并且這個(gè)繼承鏈開始于object類),否則會(huì)報(bào)錯(cuò)。如果改成下面的形式:
class Foo:
def hi(self):
print 'hi,Foo'
class Foo2(Foo):
def hi(self):
super(Foo2, self).hi()
if __name__ == '__main__':
foo2 = Foo2()
foo2.hi()
運(yùn)行時(shí)報(bào)錯(cuò)如下:
......
TypeError: must be type, not classobj
關(guān)于super,具體請(qǐng)見http://docs.python.org/2/library/functions.html?highlight=super#super以及super.doc。
五、類變量和實(shí)例變量
類變量定義在類的定義之后,實(shí)例變量則是以為self.開頭。例如:
class Foo(object):
val = 0
def __init__(self):
self.val = 1
if __name__ == '__main__':
foo = Foo()
print foo.val
print Foo.val
運(yùn)行結(jié)果為:
1
0
實(shí)例也能夠訪問類變量,如下:
class Foo(object):
val = 0
def __init__(self):
pass
if __name__ == '__main__':
foo = Foo()
print foo.val
print Foo.val
運(yùn)行結(jié)果如下:
0
0
另外,可以通過以下方式訪問類變量:
class Foo(object):
val = 3
def __init__(self):
print self.__class__.val
if __name__ == '__main__':
foo = Foo()
運(yùn)行結(jié)果:
3
還可以這樣:
class Foo(object):
val = 3
def __init__(self):
pass
@classmethod
def echo(cls):
print cls.val
if __name__ == '__main__':
Foo.echo()
運(yùn)行結(jié)果:
3
六、如何調(diào)用父類的構(gòu)造函數(shù)
子類(派生類)并不會(huì)自動(dòng)調(diào)用父類(基類)的init方法,例如:
class Foo(object):
def __init__(self):
self.val = 1
class Foo2(Foo):
def __init__(self):
print self.val
if __name__ == '__main__':
foo2 = Foo2()
運(yùn)行時(shí)報(bào)錯(cuò)。
調(diào)用父類的init方法有兩種,第一種:
class Foo(object):
def __init__(self):
self.val = 1
class Foo2(Foo):
def __init__(self):
Foo.__init__(self)
print self.val
if __name__ == '__main__':
foo2 = Foo2()
第二種:
class Foo(object):
def __init__(self):
self.val = 1
class Foo2(Foo):
def __init__(self):
super(Foo2,self).__init__()
print self.val
if __name__ == '__main__':
foo2 = Foo2()
這兩種方法的運(yùn)行結(jié)果均為:
1
不過這兩種方法是有區(qū)別的。
相關(guān)文章
在Python的Flask框架中驗(yàn)證注冊(cè)用戶的Email的方法
這篇文章主要介紹了在Python的Flask框架中驗(yàn)證注冊(cè)用戶的Email的方法,包括非常詳細(xì)的測(cè)試過程,極力推薦!需要的朋友可以參考下2015-09-09Python實(shí)現(xiàn)快速傅里葉變換的方法(FFT)
這篇文章主要介紹了Python實(shí)現(xiàn)快速傅里葉變換的方法(FFT),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07使用Python實(shí)現(xiàn)合并多個(gè)Excel文件
合并Excel可以將多個(gè)文件中的數(shù)據(jù)合并到一個(gè)文件中,這樣可以幫助我們更好地匯總和管理數(shù)據(jù),本文主要介紹了如何使用第三方Python庫 Spire.XLS for Python 實(shí)現(xiàn)以上兩種合并Excel文件的需求,有需要的可以了解下2023-12-12python+elasticsearch實(shí)現(xiàn)標(biāo)簽匹配計(jì)數(shù)操作
這篇文章主要介紹了python+elasticsearch實(shí)現(xiàn)標(biāo)簽匹配計(jì)數(shù)操作,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04Boston數(shù)據(jù)集預(yù)測(cè)放假及應(yīng)用優(yōu)缺點(diǎn)評(píng)估
這篇文章主要為大家介紹了Boston數(shù)據(jù)集預(yù)測(cè)放假及應(yīng)用優(yōu)缺點(diǎn)評(píng)估,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10Python如何實(shí)現(xiàn)播放本地音樂并在web頁面播放
這篇文章主要為大家詳細(xì)介紹了Python如何實(shí)現(xiàn)播放本地音樂并在web頁面播放,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-02-02Python基于OpenCV實(shí)現(xiàn)人臉檢測(cè)并保存
這篇文章主要介紹了Python基于OpenCV實(shí)現(xiàn)人臉檢測(cè)并保存,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07Python中使用封裝類還是函數(shù)以及它們的區(qū)別
在Python編程中,類和函數(shù)都是重要的代碼組織工具,但它們?cè)诜庋b性、狀態(tài)保持、可重用性、繼承與多態(tài)、設(shè)計(jì)模式、代碼組織、執(zhí)行流程、參數(shù)傳遞、返回值和上下文管理等方面存在明顯區(qū)別2024-10-10