本文實(shí)例講述了Python中Class類用法。分享給大家供大家參考,具體如下:
盡管Python在Function Programming中有著其他語(yǔ)言難以企及的的優(yōu)勢(shì),但是我們也不要忘了Python也是一門(mén)OO語(yǔ)言哦。因此我們關(guān)注Python在FP上的優(yōu)勢(shì)的同時(shí),還得了解一下Python在OO方面的特性。
要討論P(yáng)ython的OO特性,了解Python中的Class自然是首當(dāng)其沖了。在Python中定義class和創(chuàng)建對(duì)象實(shí)例都很簡(jiǎn)單,具體代碼如下:
class GrandPa: def __init__(self): print('I/'m GrandPa')class Father(GrandPa): def __init__(self): print('I/'m Father!')class Son(Father): """A simple example class""" i = 12345 def __init__(self): print('這是構(gòu)造函數(shù),son') def sayHello(self): return 'hello world'if __name__ == '__main__': son = Son() # 類型幫助信息 print('類型幫助信息: ',Son.__doc__) #類型名稱 print('類型名稱:',Son.__name__) #類型所繼承的基類 print('類型所繼承的基類:',Son.__bases__) #類型字典 print('類型字典:',Son.__dict__) #類型所在模塊 print('類型所在模塊:',Son.__module__) #實(shí)例類型 print('實(shí)例類型:',Son().__class__)運(yùn)行效果如下:
Python 3.3.2 (v3.3.2:d047928ae3f6, May 16 2013, 00:03:43) [MSC v.1600 32 bit (Intel)] on win32Type "copyright", "credits" or "license()" for more information.>>> ================================ RESTART ================================>>> 這是構(gòu)造函數(shù),son類型幫助信息: A simple example class類型名稱: Son類型所繼承的基類: (<class '__main__.Father'>,)類型字典: {'__module__': '__main__', 'sayHello': <function Son.sayHello at 0x010194F8>, '__doc__': 'A simple example class', '__init__': <function Son.__init__ at 0x010194B0>, 'i': 12345}類型所在模塊: __main__這是構(gòu)造函數(shù),son實(shí)例類型: <class '__main__.Son'>>>>Python支持多重繼承
首先第一點(diǎn),你會(huì)發(fā)現(xiàn)Class的定義中有一個(gè)括號(hào),這是體現(xiàn)繼承的地方。 Java用extends,C#、C++用冒號(hào)(:),Python則用括號(hào)了。從括號(hào)中包含著兩個(gè)值,聰明的你一定可以發(fā)現(xiàn):Python支持多重繼承;
__init__是Class中的構(gòu)造函數(shù)
第二點(diǎn),__init__是Class中的構(gòu)造函數(shù),兩種不同形式的構(gòu)造函數(shù)體現(xiàn)了Python支持函數(shù)重載。在構(gòu)造函數(shù)中,有一個(gè)特別的參數(shù)self,其含義與我們?cè)贘ava和C#中常見(jiàn)的this是一樣的。在這里需要強(qiáng)調(diào)一點(diǎn):在Class中定義的方法實(shí)質(zhì)上也是function,但是在方法定義的時(shí)候必須包含self這個(gè)參數(shù),而且必須將self這個(gè)參數(shù)放在第一位;
python成員變量
第三點(diǎn),在Python中,你并不需要顯式的聲明Class的Data Members,而是在賦值的時(shí)候,被賦值的變量就相應(yīng)成為了Class的Data Memebers,正如代碼中的x和y。不僅你不需要顯式的聲明Data Members,更加特別的,你甚至可以通過(guò)del方法將Class中的Data Memebers給刪掉。當(dāng)我第一次看到這樣的特性的時(shí)候,著實(shí)吃了一驚。畢竟OO的第一條就是封裝了,但是這樣的特性是不是破壞了封裝的特性呢?
python方法二義性問(wèn)題
第四點(diǎn),由于Python支持多重繼承,因此就有可能出現(xiàn)方法二義性問(wèn)題[1]。然而由于Python遵循深度優(yōu)先的搜尋法則,很好地避免了方法二義性的問(wèn)題。例如在以上的代碼中,MyClass同時(shí)繼承于BaseClassA和BaseClassB,假設(shè)MyClass調(diào)用一個(gè)叫derivedMethod方法,derivedMethod同時(shí)定義在BaseClassA和BaseClassB中,且Signature也完全相同,那么BaseClassA中的方法將被調(diào)用。如果BaseClassA中并沒(méi)有定義derivedMethod,而是BaseClassA的父類定義了這個(gè)方法的話,將會(huì)是BaseClassA的父類中derivedMethod被調(diào)用??傊^承方法搜索的路徑是先從左到右,在選定了一個(gè)BaseClass之后,將會(huì)一直沿著該BaseClass的繼承結(jié)構(gòu)進(jìn)行搜索,直至最頂端,然后再到另外一個(gè)一個(gè)BaseClass。
就先說(shuō)著這么多了,對(duì)于Python中OO的特性將會(huì)在以后的Post中有進(jìn)一步的講述。
方法二義性:由于一個(gè)類同時(shí)繼承于兩個(gè)或者多個(gè)父類,而在這些父類當(dāng)中存在著signature完全相同的方法,那么編譯器將無(wú)法判斷子類將繼承哪個(gè)父類中的方法,從而導(dǎo)致方法二義性問(wèn)題。
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選