Python中Class類用法實(shí)例分析
本文實(shí)例講述了Python中Class類用法。分享給大家供大家參考,具體如下:
盡管Python在Function Programming中有著其他語(yǔ)言難以企及的的優(yōu)勢(shì),但是我們也不要忘了Python也是一門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 win32
Type "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#中常見的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方法二義性問題
第四點(diǎn),由于Python支持多重繼承,因此就有可能出現(xiàn)方法二義性問題[1]。然而由于Python遵循深度優(yōu)先的搜尋法則,很好地避免了方法二義性的問題。例如在以上的代碼中,MyClass同時(shí)繼承于BaseClassA和BaseClassB,假設(shè)MyClass調(diào)用一個(gè)叫derivedMethod方法,derivedMethod同時(shí)定義在BaseClassA和BaseClassB中,且Signature也完全相同,那么BaseClassA中的方法將被調(diào)用。如果BaseClassA中并沒有定義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)致方法二義性問題。
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Python中使用ConfigParser解析ini配置文件實(shí)例
這篇文章主要介紹了Python中使用ConfigParser解析ini配置文件實(shí)例,本文給出了創(chuàng)建和讀取ini文件的例子,需要的朋友可以參考下2014-08-08
使用python編寫腳本獲取手機(jī)當(dāng)前應(yīng)用apk的信息
使用aapt工具獲取apk的信息,保存至腳本所在目錄下的PackageInfo.txt文件中,需要的朋友可以參考下2014-07-07
Python使用APScheduler實(shí)現(xiàn)定時(shí)任務(wù)過(guò)程解析
這篇文章主要介紹了Python使用APScheduler實(shí)現(xiàn)定時(shí)任務(wù)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
python實(shí)現(xiàn)的jpg格式圖片修復(fù)代碼

