摘要:看一個簡單的例子在實(shí)際實(shí)驗(yàn)中,加不加并沒有區(qū)別。僅作了解這是個有趣的裝飾器,傳入的參數(shù)被打上了,當(dāng)下一次傳入的參數(shù)是一樣的時候,就會從中直接取出對應(yīng)的值,而不需要進(jìn)行重新的運(yùn)算。這樣做的好處是可以幫助我們分離代碼邏輯輸出
functools
functools 包含了用于創(chuàng)建裝飾函數(shù),啟動面向切面的編程,超出面向?qū)ο缶幊谭秶拇a復(fù)用,同時提供了裝飾函數(shù)用于豐富的快捷比較的API, partial 模塊還創(chuàng)建了包含函數(shù)參數(shù)的函數(shù)引用,也就是偏函數(shù)
partial 偏函數(shù)partial 的作用在于如果存在一個函數(shù)的參數(shù)過多,可以通過partial 固定某一些參數(shù),需要的時候使用關(guān)鍵字參數(shù)傳入即可.通過一個簡單的例子理解
import functools def myfunc(a,b): print("This is myfuc params:{},{}".format(a,b)) a = functools.partial(myfunc,b=1) a(10000)
可以看到,本來調(diào)用myfunc的話,要傳入兩個參數(shù),現(xiàn)在通過固定住某些參數(shù),可以直接調(diào)用一個參數(shù)即可。除此之外,還可以通過另外一種方式來進(jìn)行傳值
import functools def myfunc(a,b): print("This is myfuc params:{},{}".format(a,b)) a = functools.partial(myfunc,b=1) value= {"a":1000} a(**value)Comparison
functools還提供了豐富用于比較的API,在python2 中,在一個類中可以定義 __cmp__() 方法,用于對象中的比較操作,python3 廢除了這樣的做法,因?yàn)樘峁┝烁釉敿?xì)的API方法,比如 __lt__() , __le__(), __eq__(),__ne__(),__gt__(),__ge__() 這些方法的含義如下:
lt:less than 小于
le:less than or equal to 小于等于
eq:equal to 等于
ne:not equal to 不等于
ge:greater than or equal to 大于等于
gt:greater than 大于
functools 提供了一個裝飾器,讓我們不需要寫這么多定義,只要寫一個,其他定義也會加上去。 看一個簡單的例子
import functools @functools.total_ordering class MyObject(): def __init__(self,priority): self.priority = priority def __eq__(self,other): print("dengyu") return self.priority == other.priority def __lt__(self,other): return self.priority < other.priority if __name__ =="__main__": a = MyObject(1) print(dir(a))
在實(shí)際實(shí)驗(yàn)中,加不加并沒有區(qū)別。僅作了解
lru_cache這是個有趣的裝飾器,傳入的參數(shù)被打上了hash,當(dāng)下一次傳入的參數(shù)是一樣的時候,就會從cache中直接取出對應(yīng)的值,而不需要進(jìn)行重新的運(yùn)算。一個簡單的例子
import functools @functools.lru_cache() def test_method(a,b): print("execute {} * {} = {}".format(a,b,a*b)) return a*b s = 0 for i in range(2): for j in range(2): s+=test_method(i,j) print(test_method.cache_info()) for i in range(2): for j in range(3): s+=test_method(i,j) print(test_method.cache_info()) print(s) # 4 說明該執(zhí)行的還是有執(zhí)行,只不過是從cache中直接取出而已通用函數(shù)
對于python來說,很難去固定一個參數(shù)必須是什么類型的,只能在具體的代碼里面進(jìn)行檢查,functools提供了一個裝飾器,可以去做這樣的類型檢查.一個簡單的例子
import functools @functools.singledispatch def myfunc(args): print(args) @myfunc.register(list) def myfunc_list(args): for i in args: print("List item: {}".format(i)) if __name__ == "__main__": # 傳入兩個不同的類型參數(shù),其處理邏輯也是不同 myfunc([1,2,3,6,4,5]) # 但是其調(diào)用的接口是一樣的。 這樣做的好處是可以幫助我們分離代碼邏輯 myfunc("Hello World")
輸出:
List item: 1 List item: 2 List item: 3 List item: 6 List item: 4 List item: 5 Hello World
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/42992.html
摘要:來源于阿賢博客模塊化今天給大家寫一篇關(guān)于前端模塊化開發(fā)知識點(diǎn)。前端模塊化開發(fā)那點(diǎn)歷史模塊化是指在解決某個復(fù)雜混雜問題時,依照一種分類的思維把問題進(jìn)行系統(tǒng)性的分解以之處理。 來源于:阿賢博客 javascript模塊化 今天給大家寫一篇關(guān)于前端模塊化開發(fā)知識點(diǎn)。 前端模塊化開發(fā)那點(diǎn)歷史 模塊化: 是指在解決某個復(fù)雜、混雜問題時,依照一種分類的思維把問題進(jìn)行系統(tǒng)性的分解以之處理。模塊...
摘要:模塊更新時部分不需被替換的模塊,檢測到或參數(shù)變化增加移除或修改參數(shù)時觸發(fā),如所有頁面的部分總是不變,此時它將不會被替換。模塊函數(shù)將在模板指令與狀態(tài)數(shù)據(jù)中講解繼續(xù)學(xué)習(xí)下一節(jié)教程模板指令與狀態(tài)數(shù)據(jù)也可回顧上一節(jié)教程啟動路由 正如它的名字,模塊用于amaplejs單頁應(yīng)用的頁面分割,所有的跳轉(zhuǎn)更新和代碼編寫都是以模塊為單位的。 定義一個模塊 一個模塊由標(biāo)簽對包含,內(nèi)部分為template模板...
摘要:模塊更新時部分不需被替換的模塊,檢測到或參數(shù)變化增加移除或修改參數(shù)時觸發(fā),如所有頁面的部分總是不變,此時它將不會被替換。模塊函數(shù)將在模板指令與狀態(tài)數(shù)據(jù)中講解繼續(xù)學(xué)習(xí)下一節(jié)教程模板指令與狀態(tài)數(shù)據(jù)也可回顧上一節(jié)教程啟動路由 正如它的名字,模塊用于amaplejs單頁應(yīng)用的頁面分割,所有的跳轉(zhuǎn)更新和代碼編寫都是以模塊為單位的。 定義一個模塊 一個模塊由標(biāo)簽對包含,內(nèi)部分為template模板...
摘要:模塊更新時部分不需被替換的模塊,檢測到或參數(shù)變化增加移除或修改參數(shù)時觸發(fā),如所有頁面的部分總是不變,此時它將不會被替換。模塊函數(shù)將在模板指令與狀態(tài)數(shù)據(jù)中講解繼續(xù)學(xué)習(xí)下一節(jié)教程模板指令與狀態(tài)數(shù)據(jù)也可回顧上一節(jié)教程啟動路由 正如它的名字,模塊用于amaplejs單頁應(yīng)用的頁面分割,所有的跳轉(zhuǎn)更新和代碼編寫都是以模塊為單位的。 定義一個模塊 一個模塊由標(biāo)簽對包含,內(nèi)部分為template模板...
閱讀 1139·2021-11-08 13:13
閱讀 1721·2019-08-30 15:55
閱讀 2772·2019-08-29 11:26
閱讀 2439·2019-08-26 13:56
閱讀 2560·2019-08-26 12:15
閱讀 2143·2019-08-26 11:41
閱讀 1402·2019-08-26 11:00
閱讀 1540·2019-08-23 18:30