亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一文帶你深入理解Python的`functools.lru_cache`裝飾器

 更新時間:2023年07月02日 14:07:19   作者:小小張說故事  
Python中的functools.lru_cache裝飾器是一個非常有用的裝飾器,它可以幫助我們優(yōu)化遞歸函數(shù),避免重復計算已經(jīng)計算過的值,在這篇文章中,我們將探討?functools.lru_cache?的工作原理以及如何使用它,感興趣的朋友跟著小編一起來學習吧

一、什么是 functools.lru_cache?

functools.lru_cache 是 Python 標準庫中 functools 模塊的一部分。lru_cache 裝飾器可以用來為一個函數(shù)添加一個緩存系統(tǒng)。這個緩存系統(tǒng)會存儲函數(shù)的輸入和對應的輸出。如果函數(shù)被調用,并且給出了已經(jīng)緩存過的輸入,那么函數(shù)就不會重新計算,而是直接從緩存中獲取對應的輸出。

LRU 是 “Least Recently Used” 的縮寫,意思是 “最近最少使用”。LRU 緩存就是一種緩存淘汰算法,當緩存達到預設的容量上限時,會優(yōu)先淘汰最近最少使用的數(shù)據(jù)。

from functools import lru_cache
@lru_cache(maxsize=None)
def fib(n):
    if n < 2:
        return n
    return fib(n - 1) + fib(n - 2)
print(fib(10))  # 輸出:55

在上面的例子中,我們定義了一個求斐波那契數(shù)列的函數(shù),并且使用 @lru_cache(maxsize=None) 裝飾器對其進行了裝飾。然后我們調用 fib(10),得到結果 55。實際上,由于使用了緩存,fib 函數(shù)在求解過程中,對于同樣的參數(shù)只進行了一次計算。

二、如何使用 functools.lru_cache?

要使用 functools.lru_cache 裝飾器,你只需要在你的函數(shù)定義之前添加 @functools.lru_cache 行。這會讓 lru_cache 裝飾器知道你希望為這個函數(shù)添加一個緩存系統(tǒng)。

lru_cache 裝飾器有兩個可選參數(shù):

  • maxsize:這個參數(shù)用來設置緩存的大小。如果你設置了這個參數(shù),緩存的大小就會被限制在這個值之內。如果你不設置這個參數(shù),或者將其設置為 None,那么緩存的大小就沒有上限。

  • typed:如果你將這個參數(shù)設置為 True,那么 lru_cache 就會根據(jù)輸入?yún)?shù)的類型分別進行緩存。也就是說,11.0 盡管在 Python 中是相等的,但它們會被當成兩個不同的輸入進行緩存。默認情況下,typed 參數(shù)是 False。

from functools import lru_cache
@lru_cache(maxsize=128, typed=False)
def add(x, y):
    print(f"Calculating: {x} + {y}")
    return x + y
print(add(1, 2))  # 輸出:Calculating: 1 + 2 \n 3
print(add(1, 2))  # 輸出:3
print(add(1.0, 2.0))  # 輸出:Calculating: 1.0 + 2.0 \n 3.0
print(add(1.0, 2.0))  # 輸出:3.0

在上面的代碼中,我們定義了一個加法函數(shù) add,并使用 lru_cache 裝飾器對其進行裝飾。我們可以看到,當我們第二次調用 add(1, 2)add(1.0, 2.0) 時,add 函數(shù)并沒有重新進行計算,而是直接從緩存中獲取了結果。

三、functools.lru_cache 的用途

functools.lru_cache 可以用于優(yōu)化那些具有重復計算的遞歸函數(shù),或者計算成本較高的函數(shù)。通過保存已經(jīng)計算過的值,functools.lru_cache 能夠避免重復的計算,從而提高程序的運行效率。

例如,求解斐波那契數(shù)列就是一個典型的使用場景。在沒有優(yōu)化的情況下,求解斐波那契數(shù)列的時間復雜度是指數(shù)級別的。但是,如果我們使用 functools.lru_cache 對其進行優(yōu)化,那么我們就可以將其時間復雜度降低到線性級別。

此外,functools.lru_cache 還可以用于緩存那些對數(shù)據(jù)庫或者文件系統(tǒng)的重復查詢,從而提高程序的性能。

需要注意的是,functools.lru_cache 并不適合所有的場景。因為 functools.lru_cache 是通過空間換取時間的方式來提高程序的性能的,所以,如果你的程序運行在內存有限的環(huán)境中,或者你的函數(shù)有大量的不同輸入,那么使用 functools.lru_cache 可能會導致內存消耗過大。此外,如果你的函數(shù)有副作用,或者依賴于外部狀態(tài),那么 functools.lru_cache 也可能無法正確地工作。在這些情況下,你可能需要尋找其他的優(yōu)化策略。

總的來說,functools.lru_cache 是一個非常強大的工具,它能夠幫助我們優(yōu)化代碼,提高程序的性能。當你在編寫一個計算密集型或者需要大量重復計算的函數(shù)時,不妨考慮使用 functools.lru_cache 對其進行優(yōu)化。

四、深入理解 functools.lru_cache

當我們將 functools.lru_cache 應用到函數(shù)上時,每次調用函數(shù),它都會檢查其參數(shù)是否已經(jīng)在緩存中。如果在緩存中,它將返回緩存的結果,而不需要重新計算。如果沒有在緩存中,那么函數(shù)將被調用并且結果將被添加到緩存中。當緩存滿了,最少使用的條目將被拋棄。

以下是一個理解 functools.lru_cache 工作方式的例子:

from functools import lru_cache
@lru_cache(maxsize=3)
def foo(n):
    print(f"Running foo({n})")
    return n
print(foo(1))  # 輸出:Running foo(1) \n 1
print(foo(2))  # 輸出:Running foo(2) \n 2
print(foo(3))  # 輸出:Running foo(3) \n 3
print(foo(1))  # 輸出:1
print(foo(2))  # 輸出:2
print(foo(3))  # 輸出:3
print(foo(4))  # 輸出:Running foo(4) \n 4
print(foo(1))  # 輸出:Running foo(1) \n 1

在這個例子中,我們設定 maxsize=3,也就是只緩存最近的三個結果。當我們連續(xù)調用 foo(1)foo(2),foo(3) 時,這三個結果都被緩存了下來。再次調用這三個函數(shù)時,由于結果已經(jīng)在緩存中,函數(shù)并沒有被重新執(zhí)行。但是當我們調用 foo(4) 時,由于緩存已滿,所以最早被緩存的 foo(1) 的結果被移除了。再次調用 foo(1) 時,函數(shù)需要被重新執(zhí)行。

這個例子說明了 functools.lru_cache 的 LRU 特性:當緩存達到上限時,最近最少使用的緩存會被移除。

五、清理和查看緩存

functools.lru_cache 還提供了兩個方法用于清理和查看緩存:cache_clearcache_info。

cache_clear 方法可以清空所有的緩存。例如,在上面的 foo 函數(shù)中,我們可以通過 foo.cache_clear() 來清空所有的緩存。

cache_info 方法返回一個命名元組,描述了緩存的狀態(tài)。它包含以下幾個字段:hits、misses、maxsizecurrsize。其中,hitsmisses 分別表示緩存命中和未命中的次數(shù),maxsize 表示緩存的最大容量,currsize 表示當前緩存的使用量。

from functools import lru_cache
@lru_cache(maxsize=3)
def foo(n):
    print(f"Running foo({n})")
    return n
foo(1)
foo(2)
foo(3)
foo(4)
print(foo.cache_info())  # 輸出:CacheInfo(hits=0, misses=4, maxsize=3, currsize=3)
foo(4)
print(foo.cache_info())  # 輸出:CacheInfo(hits=1, misses=4, maxsize=3, currsize=3)
foo.cache_clear()
print(foo.cache_info())  # 輸出:CacheInfo(hits=0, misses=0, maxsize=3, currsize=0)

在這個例子中,我們首先調用了 foo(1),foo(2),foo(3)foo(4)。此時,由于 foo(1) 的緩存已經(jīng)被淘汰,緩存中僅保留了 foo(2),foo(3)foo(4) 的結果。調用 foo.cache_info(),我們可以看到緩存未命中的次數(shù)為 4,當前緩存的使用量為 3。

然后我們再次調用 foo(4),由于這個結果已經(jīng)在緩存中,所以這次是緩存命中,調用 foo.cache_info(),我們可以看到緩存命中的次數(shù)變成了 1。

最后,我們調用 foo.cache_clear() 清空了所有的緩存,再次調用 foo.cache_info(),我們可以看到當前緩存的使用量變成了 0。

以上,我們介紹了 functools.lru_cache 裝飾器的使用方法和原理,包括如何使用 lru_cache 對函數(shù)進行優(yōu)化,以及如何清理和查看緩存。希望這篇文章能夠幫助你更好地理解和使用 functools.lru_cache。

到此這篇關于一文帶你深入理解Python的`functools.lru_cache`裝飾器的文章就介紹到這了,更多相關Python `functools.lru_cache`裝飾器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • python寫入數(shù)據(jù)到csv或xlsx文件的3種方法

    python寫入數(shù)據(jù)到csv或xlsx文件的3種方法

    這篇文章主要為大家詳細介紹了python寫入數(shù)據(jù)到csv或xlsx文件的3種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • python實現(xiàn)靜態(tài)服務器

    python實現(xiàn)靜態(tài)服務器

    這篇文章主要為大家詳細介紹了python實現(xiàn)靜態(tài)服務器,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • python之matplotlib學習繪制動態(tài)更新圖實例代碼

    python之matplotlib學習繪制動態(tài)更新圖實例代碼

    這篇文章主要介紹了python之matplotlib學習繪制動態(tài)更新圖實例代碼,文中涉及具體實現(xiàn)代碼,演示效果及運行時出現(xiàn)的問題分析等相關內容,小編覺得還是挺不錯的,這里分享給大家,需要的朋友可以參考下
    2018-01-01
  • 關于python中map函數(shù)的使用

    關于python中map函數(shù)的使用

    這篇文章主要介紹了關于python中map函數(shù)的使用,map函數(shù)也是python中的一個內置函數(shù),用法同之前講過的filter函數(shù)類似,需要的朋友可以參考下
    2023-04-04
  • Python中Numpy和Matplotlib的基本使用指南

    Python中Numpy和Matplotlib的基本使用指南

    numpy庫處理的最基礎數(shù)據(jù)類型是由同種元素構成的多維數(shù)組(ndarray),而matplotlib 是提供數(shù)據(jù)繪圖功能的第三方庫,其pyplot子庫主要用于實現(xiàn)各種數(shù)據(jù)展示圖形的繪制,這篇文章主要給大家介紹了關于Python中Numpy和Matplotlib的基本使用指南,需要的朋友可以參考下
    2021-11-11
  • python實現(xiàn)商品進銷存管理系統(tǒng)

    python實現(xiàn)商品進銷存管理系統(tǒng)

    這篇文章主要為大家詳細介紹了python實現(xiàn)商品進銷存管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Python random模塊制作簡易的四位數(shù)驗證碼

    Python random模塊制作簡易的四位數(shù)驗證碼

    這篇文章主要介紹了Python random模塊制作簡易的四位數(shù)驗證碼,文中給大家提到了python中random模塊的相關知識,需要的朋友可以參考下
    2020-02-02
  • Python使用lambda表達式對字典排序操作示例

    Python使用lambda表達式對字典排序操作示例

    這篇文章主要介紹了Python使用lambda表達式對字典排序操作,結合實例形式分析了lambda表達式實現(xiàn)字典按鍵排序、按值排序、多條件排序相關操作技巧,需要的朋友可以參考下
    2019-07-07
  • python實現(xiàn)超級馬里奧

    python實現(xiàn)超級馬里奧

    這篇文章主要為大家詳細介紹了python實現(xiàn)超級馬里奧,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 詳解Python開發(fā)中如何使用Hook技巧

    詳解Python開發(fā)中如何使用Hook技巧

    這篇文章主要介紹了詳解Python開發(fā)中如何使用Hook技巧,詳細的介紹了Python Hook的用法和示例,有興趣的可以了解一下
    2017-11-11

最新評論