1. 程式人生 > >Python深入01 特殊方法與多範式

Python深入01 特殊方法與多範式

同時 與運算 false 進行 spa 下劃線 round als UNC

Python一切皆對象,但同時,Python還是一個多範式語言(multi-paradigm),你不僅可以使用面向對象的方式來編寫程序,還可以用面向過程的方式來編寫相同功能的程序(還有函數式、聲明式等,我們暫不深入)。Python的多範式依賴於Python對象中的特殊方法(special method)

特殊方法名的前後各有兩個下劃線。特殊方法又被成為魔法方法(magic method),定義了許多Python語法和表達方式,正如我們在下面的例子中將要看到的。當對象中定義了特殊方法的時候,Python也會對它們有“特殊優待”。比如定義了__init__()方法的類,會在創建對象的時候自動執行__init__()方法中的操作。

(可以通過dir()來查看對象所擁有的特殊方法,比如dir(1))

運算符

Python的運算符是通過調用對象的特殊方法實現的。比如:

abc + xyz   # 連接字符串

實際執行了如下操作:

abc.__add__(xyz)

所以,在Python中,兩個對象是否能進行加法運算,首先就要看相應的對象是否有__add__()方法。一旦相應的對象有__add__()方法,即使這個對象從數學上不可加,我們都可以用加法的形式,來表達obj.__add__()所定義的操作。在Python中,運算符起到簡化書寫的功能,但它依靠特殊方法實現。

Python不強制用戶使用面向對象的編程方法。用戶可以選擇自己喜歡的使用方式(比如選擇使用+符號,還是使用更加面向對象的__add__()方法)。特殊方法寫起來總是要更費事一點。

嘗試下面的操作,看看效果,再想想它的對應運算符

(1.8).__mul__(2.0)

True.__or__(False)

內置函數

與運算符類似,許多內置函數也都是調用對象的特殊方法。比如

len([1,2,3])      # 返回表中元素的總數

實際上做的是

[1,2,3].__len__()

相對與__len__(),內置函數len()也起到了簡化書寫的作用。

嘗試下面的操作,想一下它的對應內置函數

(-1).__abs__()

(2.3).__int__()

表(list)元素引用

下面是我們常見的表元素引用方式

li = [1, 2, 3, 4, 5, 6]
print
(li[3])

上面的程序運行到li[3]的時候,Python發現並理解[]符號,然後調用__getitem__()方法。

li = [1, 2, 3, 4, 5, 6]
print(li.__getitem__(3))

嘗試看下面的操作,想想它的對應

li.__setitem__(3, 0)

{‘a‘:1, ‘b‘:2}.__delitem__(‘a‘)

函數

我們已經說過,在Python中,函數也是一種對象。實際上,任何一個有__call__()特殊方法的對象都被當作是函數。比如下面的例子:

技術分享圖片
class SampleMore(object):
def __call__(self, a): return a + 5
add
= SampleMore() # A function object print(add(2)) # Call function map(add, [2, 4, 5]) # Pass around function object
技術分享圖片

Python深入01 特殊方法與多範式