標準的Python語言進行說明介紹
Python語言具有一個標準的unittest模塊,可以用來編寫xUnit風(fēng)格的測試。您可以重復(fù)利用設(shè)置/拆卸代碼,以適當?shù)姆绞絹斫M織你的測試,甚至可以運行你的測試。下面是一個用于部分函數(shù)add5()的單元測試。
TestAdd5類由unittest.TestCase派生而來,并定義了一個setUp()方法,該方法將在執(zhí)行每個測試方法之前調(diào)用。它能確保某些一致狀態(tài)可以用于所有的測試方法。此測試方法會調(diào)用unittest的assertEqual()和assert_()方法。如果任何調(diào)用失敗,托管的測試方法就會認為出現(xiàn)了一個故障,并轉(zhuǎn)到下一個測試。
部分函數(shù)是一個惹人喜愛的函數(shù)特性。它們可以讓您的函數(shù)接收X個參數(shù)的函數(shù),同時,將一些參數(shù)固定,就能得到一個只能接收您沒規(guī)定的參數(shù)的新函數(shù)。下面舉例進行說明,函數(shù)add()可接收兩個參數(shù),并返回結(jié)果,現(xiàn)在如果把一個參數(shù)固定為5,我們就會得到一個新函數(shù)——僅僅接收一個參數(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
當使用要求參數(shù)總是相同的API的時候,部分函數(shù)會非常有用??梢钥紤]一個web應(yīng)用程序接口,在每個方法中都是要求一個用戶名和一個密碼。如果您創(chuàng)建一個固定了用戶名和口令的部分函數(shù),會給開發(fā)帶來非常大的便利,因為您不必傳遞參數(shù)了。
同時,您的代碼也會因此而變得更安全,因為用戶名和密碼不會出現(xiàn)在所有調(diào)用站點中。然而,直到Python 3.1為止,部分函數(shù)仍有許多讓人不快的限制。 因為它們無法封裝。好在Python 3.1解決了這個問題,下面是一個例子:
- 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模塊進行并行程序設(shè)計的時候,人們喜歡把函數(shù)和部分函數(shù)封裝起來。自Python 2.6以來,processing模塊已經(jīng)成為標準程序庫的一部分。是利用現(xiàn)代多核機器的***Python解決方案。實際上,processing模塊會封裝進程之間傳遞的所有一切,所以可封裝的部分函數(shù)提高了它的表達力并增加了可用的工具。
【編輯推薦】