婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python 的lru_cache裝飾器使用簡介

Python 的lru_cache裝飾器使用簡介

熱門標(biāo)簽:女王谷地圖標(biāo)注 百應(yīng)ai電銷機器人鄭州 廈門crm外呼系統(tǒng)如何 西藏快速地圖標(biāo)注地點 長春人工智能電銷機器人官網(wǎng) 地圖標(biāo)注推廣單頁 如何在地圖標(biāo)注文字 ai地圖標(biāo)注 n400電話申請多少錢

Python 的 lru_cache 裝飾器是一個為自定義函數(shù)提供緩存功能的裝飾器。其內(nèi)部會在下次以相同參數(shù)調(diào)用該自定義函數(shù)時直接返回計算好的結(jié)果。通過緩存計算結(jié)果可以很好地提升性能。

1 從示例說起

假設(shè)我們有一個計算斐波那契數(shù)列的求和函數(shù),其內(nèi)部采用遞歸方式實現(xiàn)。

from xxx.clock_decorator import clock

@clock
def fibonacci(n):
 if n2:
  return n
 return fibonacci(n-2)+fibonacci(n-1)

if __name__=='__main__':
 logging.info('fibonacci(6) -> %s',fibonacci(6))

運行結(jié)果:

其中的 clock_decorator 實現(xiàn)是一個可以輸出某個函數(shù)運行時長的裝飾器1。

從輸出結(jié)果中可以看出,存在著嚴重的重復(fù)計算情況,比如 fibonacci(1) 就被計算了 5 次之多。這還只是計算 6 次的 fibonacci 函數(shù)。

2 優(yōu)化

上面的示例代碼加入 lru_cache 裝飾器:

運行結(jié)果:

這次不存在重復(fù)計算現(xiàn)象,因此性能得到極大的提升。

3 比較

利用 cProfile 進行性能比較分析。它是一種確定性分析器,只測量 CPU 時間,并不包含內(nèi)存消耗和其他與內(nèi)存相關(guān)聯(lián)的信息2。

假設(shè)我們需要計算 fibonacci(33) 求和值。

(1)不使用 lru_cache 裝飾器

這個遞歸函數(shù)內(nèi)部總共調(diào)用了 1000 多萬次的 fibonacci() 函數(shù)!

(2)使用了 lru_cache 裝飾器

使用了 lru_cache 裝飾器之后,這個遞歸函數(shù)只需調(diào)用 100 多次fibonacci() 函數(shù)!性能有了質(zhì)的提升。

4 lru_cache 裝飾器

lru_cache 裝飾器支持兩個入?yún)ⅲ耐暾x格式為3: @functools.lru_cache(maxsize=128, typed=False)

參數(shù)  默認值  說明
maxsize  128  表示緩存大小。如果設(shè)置為 None,則不限大小;如果超過緩存大小,則使用 LRU 策略清理緩存。緩存的大小限制可確保緩存不會無限制增長。LRU(Least Recently Used),即刪除最近最少使用的緩存數(shù)據(jù)。
typed  False  如果為true,不同類型的參數(shù)將會被分別緩存,比如區(qū)分浮點數(shù)與整型。
注意:由于使用了字典來存儲緩存,所以所裝飾的函數(shù)參數(shù)必須是可哈希的。
利用 cache_info() 函數(shù),我們還可以看到命中次數(shù) hits,未命中次數(shù) misses ,最大緩存數(shù)量 maxsize 和 當(dāng)前緩存大小 currsize。使用方式是直接調(diào)用被裝飾函數(shù)的 cache_info(),形如:fibonacci.cache_info())。

只要某個函數(shù)遞歸調(diào)用并存在重復(fù)計算的情況,這時就要記著使用 lru_cache 這個性能加速器。

以上就是Python 的lru_cache 裝飾器使用簡介的詳細內(nèi)容,更多關(guān)于Python 的lru_cache 裝飾器的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Python中l(wèi)ru_cache的使用和實現(xiàn)詳解
  • Python實現(xiàn)的一個簡單LRU cache
  • python自帶緩存lru_cache用法及擴展的使用

標(biāo)簽:綿陽 廊坊 拉薩 內(nèi)江 黔東 亳州 興安盟 渭南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python 的lru_cache裝飾器使用簡介》,本文關(guān)鍵詞  Python,的,lru,cache,裝飾,器,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python 的lru_cache裝飾器使用簡介》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python 的lru_cache裝飾器使用簡介的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 甘肃省| 尤溪县| 柘城县| 那坡县| 桐庐县| 兴隆县| 页游| 明星| 石泉县| 永丰县| 长治市| 万载县| 海门市| 泉州市| 衡东县| 平安县| 吉木乃县| 陆丰市| 中江县| 云林县| 沾益县| 泗阳县| 南和县| 绥江县| 五台县| 延安市| 汉源县| 黎城县| 银川市| 南靖县| 上思县| 浮梁县| 沾益县| 张家口市| 淮阳县| 夹江县| 西贡区| 合江县| 新兴县| 丽水市| 平阴县|