標(biāo)準(zhǔn)的Python語(yǔ)言進(jìn)行說明介紹
Python語(yǔ)言具有一個(gè)標(biāo)準(zhǔn)的unittest模塊,可以用來編寫xUnit風(fēng)格的測(cè)試。您可以重復(fù)利用設(shè)置/拆卸代碼,以適當(dāng)?shù)姆绞絹斫M織你的測(cè)試,甚至可以運(yùn)行你的測(cè)試。下面是一個(gè)用于部分函數(shù)add5()的單元測(cè)試。
TestAdd5類由unittest.TestCase派生而來,并定義了一個(gè)setUp()方法,該方法將在執(zhí)行每個(gè)測(cè)試方法之前調(diào)用。它能確保某些一致狀態(tài)可以用于所有的測(cè)試方法。此測(cè)試方法會(huì)調(diào)用unittest的assertEqual()和assert_()方法。如果任何調(diào)用失敗,托管的測(cè)試方法就會(huì)認(rèn)為出現(xiàn)了一個(gè)故障,并轉(zhuǎn)到下一個(gè)測(cè)試。
部分函數(shù)是一個(gè)惹人喜愛的函數(shù)特性。它們可以讓您的函數(shù)接收X個(gè)參數(shù)的函數(shù),同時(shí),將一些參數(shù)固定,就能得到一個(gè)只能接收您沒規(guī)定的參數(shù)的新函數(shù)。下面舉例進(jìn)行說明,函數(shù)add()可接收兩個(gè)參數(shù),并返回結(jié)果,現(xiàn)在如果把一個(gè)參數(shù)固定為5,我們就會(huì)得到一個(gè)新函數(shù)——僅僅接收一個(gè)參數(shù),代碼如下所示:
- Traceback (most recent call last):
- File "test_partial_pickle.py", line 12, in <module>
- s = pickle.dumps(partial(add, 10))
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/pickle.py", line 1366, in dumps
- Pickler(file, protocol).dump(obj)
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/pickle.py", line 224, in dump
- self.save(obj)
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/pickle.py", line 306, in save
- rv = reduce(self.proto)
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/copy_reg.py", line 69, in _reduce_ex
- raise TypeError, "can't pickle %s objects" % base.__name__
- TypeError: can't pickle partial objects
當(dāng)使用要求參數(shù)總是相同的API的時(shí)候,部分函數(shù)會(huì)非常有用。可以考慮一個(gè)web應(yīng)用程序接口,在每個(gè)方法中都是要求一個(gè)用戶名和一個(gè)密碼。如果您創(chuàng)建一個(gè)固定了用戶名和口令的部分函數(shù),會(huì)給開發(fā)帶來非常大的便利,因?yàn)槟槐貍鬟f參數(shù)了。
同時(shí),您的代碼也會(huì)因此而變得更安全,因?yàn)橛脩裘兔艽a不會(huì)出現(xiàn)在所有調(diào)用站點(diǎn)中。然而,直到Python 3.1為止,部分函數(shù)仍有許多讓人不快的限制。 因?yàn)樗鼈儫o法封裝。好在Python 3.1解決了這個(gè)問題,下面是一個(gè)例子:
- Traceback (most recent call last):
- File "test_partial_pickle.py", line 12, in <module>
- s = pickle.dumps(partial(add, 10))
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/pickle.py", line 1366, in dumps
- Pickler(file, protocol).dump(obj)
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/pickle.py", line 224, in dump
- self.save(obj)
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/pickle.py", line 306, in save
- rv = reduce(self.proto)
- File "/Library/Frameworks/Python.framework/Versions/
- 2.5/lib/python2.5/copy_reg.py", line 69, in _reduce_ex
- raise TypeError, "can't pickle %s objects" % base.__name__
- TypeError: can't pickle partial objects
在使用processing模塊進(jìn)行并行程序設(shè)計(jì)的時(shí)候,人們喜歡把函數(shù)和部分函數(shù)封裝起來。自Python 2.6以來,processing模塊已經(jīng)成為標(biāo)準(zhǔn)程序庫(kù)的一部分。是利用現(xiàn)代多核機(jī)器的***Python解決方案。實(shí)際上,processing模塊會(huì)封裝進(jìn)程之間傳遞的所有一切,所以可封裝的部分函數(shù)提高了它的表達(dá)力并增加了可用的工具。
【編輯推薦】