重載和重寫,這是兩個新概念,是兩個令我們?nèi)菀谆煜母拍?。方法重載(overloading method)
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供會同網(wǎng)站建設、會同做網(wǎng)站、會同網(wǎng)站設計、會同網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、會同企業(yè)網(wǎng)站模板建站服務,10年會同做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
是在一個類里面,方法名字相同,而參數(shù)不同。返回類型呢?可以相同也可以不同。方法重寫(overiding method)
子類不想原封不動地繼承父類的方法,而是想作一定的修改,這就需要采用方法的重寫。方法重寫又稱方法覆蓋。方法重載是讓類以統(tǒng)一的方式處理不同類型數(shù)據(jù)的
一種手段。Java的方法重載,就是在類中可以創(chuàng)建多個方法,它們具有相同的名字,但具有不同的參數(shù)和不同的定義。調(diào)用方法時通過傳遞給它們的不同個數(shù)和
類型的參數(shù)來決定具體使用哪個方法,
這就是多態(tài)性。方法重寫:在Java中,子類可繼承父類中的方法,而不需要重新編寫相同的方法。但有時子類并不想原封不動地繼承父類的方法,而是想作一定
的修改,這就需要采用方法的重寫。方法重寫又稱方法覆蓋。
若子類中的方法與父類中的某一方法具有相同的方法名、返回類型和參數(shù)表,則新方法將覆蓋原有的方法。
如需父類中原有的方法,可使用super關鍵字,該關鍵字引用了當前類的父類重寫方法的規(guī)則:
參數(shù)列表必須完全與被重寫的方法的相同,否則不能稱其為重寫而是重載.
返回的類型必須一直與被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載.訪問修飾符的限制一定要大于被重寫方法的訪問修飾符
(publicprotecteddefaultprivate)重寫方法一定不能拋出新的檢查異?;蛘弑缺恢貙懛椒ㄉ昝鞲訉?/p>
泛的檢查型異常.例如,父類的一個方法申明了一個檢查異常IOException,在重寫這個方法是就不能拋出Exception,只能拋出
IOException的子類異常,可以拋出非檢查異常.重載的規(guī)則:必須具有不同的參數(shù)列表;可以有不同的返回類型,只要參數(shù)列表不同就可以
了;可以有不同的訪問修飾符;可以拋出不同的異常;注意,Java的方法重載要求同名的方法必須有不同的參數(shù)表,僅有返回類型不同是不足以區(qū)分兩
個重載的方法。重寫方法只能存在于具有繼承關系中,重寫方法只能重寫父類非私有的方法。下面分別舉一個例子來說明方法重載:public class
TestOverLoad{ public static void main(String[] args) {Test test = new
Test(); test.print(null); } }class Test{ public void print(String
some){System.out.println("String version print"); } public void
print(Object some){ System.out.println("Object version print");
}}該程序輸出的結(jié)果是String version print。
*k表示可變參數(shù),通過可變參數(shù)實現(xiàn)類似于重載的方法。
通常我們要定義一個函數(shù)的時候,必須要預先定義這個函數(shù)需要多少個參數(shù)(或者說可以接受多少個參數(shù))。一般情況下這是沒問題的,但是也有在定義函數(shù)的時候,不能知道參數(shù)個數(shù)的情況(想一想C語言里的printf函數(shù)),在Python里,帶*的參數(shù)就是用來接受可變數(shù)量參數(shù)的??匆粋€例子
def funcD(a, b, *c):
print a
print b
print "length of c is: %d " % len(c)
print c
調(diào)用funcD(1, 2, 3, 4, 5, 6)結(jié)果是
1
2
length of c is: 4
(3, 4, 5, 6)
我們看到,前面兩個參數(shù)被a、b接受了,剩下的4個參數(shù),全部被c接受了,c在這里是一個tuple。我們在調(diào)用funcD的時候,至少要傳遞2個參數(shù),2個以上的參數(shù),都放到c里了,如果只有兩個參數(shù),那么c就是一個empty tuple。
估計是講不明白。只能盡力。面向?qū)ο蟮幕A需要再理解一下。
self是第一個參數(shù)。在python里是指“實例”本身。就是自己。 這個class A有一個屬性是x
other是第二個參數(shù),它代表另一個class A的實例。當然它也有一個屬性x
__add__是一個重載加號的函數(shù)。意思是將兩個class A實例相加,結(jié)果等于兩個實例的x變量相加之和。
other.x與self.x當然是指不同實例中的變量x
Python正確重載運算符的方法示例詳解
說到運算符重載相信大家都不陌生,運算符重載的作用是讓用戶定義的對象使用中綴運算符(如 + 和 |)或一元運算符(如 - 和 ~)。說得寬泛一些,在 Python 中,函數(shù)調(diào)用(())、屬性訪問(.)和元素訪問 / 切片([])也是運算符。
我們?yōu)?Vector 類簡略實現(xiàn)了幾個運算符。__add__ 和 __mul__ 方法是為了展示如何使用特殊方法重載運算符,不過有些小問題被我們忽視了。此外,我們定義的Vector2d.__eq__ 方法認為 Vector(3, 4) == [3, 4] 是真的(True),這可能并不合理。下面來一起看看詳細的介紹吧。
運算符重載基礎
在某些圈子中,運算符重載的名聲并不好。這個語言特性可能(已經(jīng))被濫用,讓程序員困惑,導致缺陷和意料之外的性能瓶頸。但是,如果使用得當,API 會變得好用,代碼會變得易于閱讀。Python 施加了一些限制,做好了靈活性、可用性和安全性方面的平衡:
不能重載內(nèi)置類型的運算符
不能新建運算符,只能重載現(xiàn)有的
某些運算符不能重載——is、and、or 和 not(不過位運算符
、| 和 ~ 可以)
前面的博文已經(jīng)為 Vector 定義了一個中綴運算符,即 ==,這個運算符由__eq__ 方法支持。我們將改進 __eq__ 方法的實現(xiàn),更好地處理不是Vector 實例的操作數(shù)。然而,在運算符重載方面,眾多比較運算符(==、!=、、、=、=)是特例,因此我們首先將在 Vector 中重載四個算術運算符:一元運算符 - 和 +,以及中綴運算符 + 和 *。
一元運算符
-(__neg__)
一元取負算術運算符。如果 x 是 -2,那么 -x == 2。
+(__pos__)
一元取正算術運算符。通常,x == +x,但也有一些例外。如果好奇,請閱讀“x 和 +x 何時不相等”附注欄。
~(__invert__)
對整數(shù)按位取反,定義為 ~x == -(x+1)。如果 x 是 2,那么 ~x== -3。
支持一元運算符很簡單,只需實現(xiàn)相應的特殊方法。這些特殊方法只有一個參數(shù),self。然后,使用符合所在類的邏輯實現(xiàn)。不過,要遵守運算符的一個基本規(guī)則:始終返回一個新對象。也就是說,不能修改self,要創(chuàng)建并返回合適類型的新實例。
對 - 和 + 來說,結(jié)果可能是與 self 同屬一類的實例。多數(shù)時候,+ 最好返回 self 的副本。abs(...) 的結(jié)果應該是一個標量。但是對 ~ 來說,很難說什么結(jié)果是合理的,因為可能不是處理整數(shù)的位,例如在ORM 中,SQL WHERE 子句應該返回反集。
def __abs__(self):
return math.sqrt(sum(x * x for x in self))
def __neg__(self):
return Vector(-x for x in self) #為了計算 -v,構(gòu)建一個新 Vector 實例,把 self 的每個分量都取反
def __pos__(self):
return Vector(self) #為了計算 +v,構(gòu)建一個新 Vector 實例,傳入 self 的各個分量
x 和 +x 何時不相等
每個人都覺得 x == +x,而且在 Python 中,幾乎所有情況下都是這樣。但是,我在標準庫中找到兩例 x != +x 的情況。
第一例與 decimal.Decimal 類有關。如果 x 是 Decimal 實例,在算術運算的上下文中創(chuàng)建,然后在不同的上下文中計算 +x,那么 x!= +x。例如,x 所在的上下文使用某個精度,而計算 +x 時,精度變了,例如下面的
將__div__換成__truediv__試試
因為在python 2.x.x 里面 / 是classic division 所以LOVESOO的回答沒有問題
在python 3.x.x / 對應的是 true division 所以試試定義 __truediv__
搜 API Changes
f=open('aaa.txt')
l=f.readline()
for
i
in
l:
if
"bbb"
in
i:
"ok
f.close()
打開文件aaa.txt
for循環(huán),一行一行的,如果bbb關鍵字在i這一行,打印ok