Python Class正確應(yīng)用代碼示例剖析
大家都知道,Python編程語(yǔ)言雖然使用簡(jiǎn)單,易于大家使用,但是其功能還是比較強(qiáng)大的。特別是在面向?qū)ο蠓矫娴膬?yōu)勢(shì)更為明顯。我們今天將會(huì)為大家詳細(xì)介紹一下Python Class的應(yīng)用方式,以此來(lái)加深對(duì)這方面的認(rèn)識(shí)。
要討論P(yáng)ython的OO特性,了解Python Class自然是首當(dāng)其沖了。在Python中定義class和創(chuàng)建對(duì)象實(shí)例都很簡(jiǎn)單,具體代碼如下:
- class MyClass(BaseClassA, BaseClassB):
- def __init__(self):
- self.x = 0
- self.y = 0
- def __init__(self, x, y):
- self.x = x
- self.y = y
"以上構(gòu)造函數(shù)的用法有誤,正確用法請(qǐng)看來(lái)自Qiangning Hong的FeedBack"
- myClass = MyClass()
- print myClass.x, myClass.y
- myClass.z = 10
- print myClass.z
- del myClass.x
看完以上的代碼,您的心中是不是有很多的問(wèn)題呢? 好,就讓我來(lái)一一作答吧。#t#
首先第一點(diǎn),你會(huì)發(fā)現(xiàn)Python Class的定義中有一個(gè)括號(hào),這是體現(xiàn)繼承的地方。 Java用extends,C#、C++用冒號(hào)(:),Python則用括號(hào)了。從括號(hào)中包含著兩個(gè)值,聰明的你一定可以發(fā)現(xiàn):Python支持多重繼承;
第二點(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ù)放在第一位;
第三點(diǎn),在Python中,你并不需要顯式的聲明Class的Data Members,而是在賦值的時(shí)候,被賦值的變量就相應(yīng)成為了Class的Data Memebers,正如代碼中的x和y。不僅你不需要顯式的聲明Data Members,更加特別的,你甚至可以通過(guò)del方法將Python Class中的Data Memebers給刪掉。當(dāng)我第一次看到這樣的特性的時(shí)候,著實(shí)吃了一驚。畢竟OO的第一條就是封裝了,但是這樣的特性是不是破壞了封裝的特性呢?
第四點(diǎn),由于Python支持多重繼承,因此就有可能出現(xiàn)方法二義性問(wèn)題。然而由于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的父類(lèi)定義了這個(gè)方法的話(huà),將會(huì)是BaseClassA的父類(lèi)中derivedMethod被調(diào)用。
總之,繼承方法搜索的路徑是先從左到右,在選定了一個(gè)BaseClass之后,將會(huì)一直沿著該BaseClass的繼承結(jié)構(gòu)進(jìn)行搜索,直至最頂端,然后再到另外一個(gè)一個(gè)BaseClass。