亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python 緩存機制與 functools.lru_cache

系統(tǒng) 1797 0
原文鏈接: https://kuanghy.github.io/2016/04/20/python-cache

緩存是一種將定量數(shù)據(jù)加以保存以備迎合后續(xù)請求的處理方式,旨在加快數(shù)據(jù)的檢索速度。

在 Python 的 3.2 版本中,引入了一個非常優(yōu)雅的緩存機器,即 functool 模塊中的 lru_cache 裝飾器。

lru_cache 原型如下:

            
              @functools
              
                .
              
              lru_cache
              
                (
              
              maxsize
              
                =
              
              
                None
              
              
                ,
              
               typed
              
                =
              
              
                False
              
              
                )
              
            
          

使用functools模塊的lur_cache裝飾器,可以緩存最多 maxsize 個此函數(shù)的調(diào)用結(jié)果,從而提高程序執(zhí)行的效率,特別適合于耗時的函數(shù)。參數(shù)maxsize為最多緩存的次數(shù),如果為None,則無限制,設(shè)置為2n時,性能最佳;如果 typed=True(注意,在 functools32 中沒有此參數(shù)),則不同參數(shù)類型的調(diào)用將分別緩存,例如 f(3) 和 f(3.0)。

被 lru_cache 裝飾的函數(shù)會有 cache_clear 和 cache_info 兩個方法,分別用于清除緩存和查看緩存信息。

一個簡單的示例演示 lru_cache 效果:

            
              
                from
              
               functools 
              
                import
              
               lru_cache
@lru_cache
              
                (
              
              
                None
              
              
                )
              
              
                def
              
              
                add
              
              
                (
              
              x
              
                ,
              
               y
              
                )
              
              
                :
              
              
                print
              
              
                (
              
              
                "calculating: %s + %s"
              
              
                %
              
              
                (
              
              x
              
                ,
              
               y
              
                )
              
              
                )
              
              
                return
              
               x 
              
                +
              
               y


              
                print
              
              
                (
              
              add
              
                (
              
              
                1
              
              
                ,
              
              
                2
              
              
                )
              
              
                )
              
              
                print
              
              
                (
              
              add
              
                (
              
              
                1
              
              
                ,
              
              
                2
              
              
                )
              
              
                )
              
              
                print
              
              
                (
              
              add
              
                (
              
              
                2
              
              
                ,
              
              
                3
              
              
                )
              
              
                )
              
            
          

輸出結(jié)果

            
              calculating
              
                :
              
              
                1
              
              
                +
              
              
                2
              
              
                3
              
              
                3
              
              
calculating
              
                :
              
              
                2
              
              
                +
              
              
                3
              
              
                5
              
            
          

從結(jié)果可以看出,當?shù)诙握{(diào)用 add(1, 2) 時,并沒有真正執(zhí)行函數(shù)體,而是直接返回緩存的結(jié)果。

轉(zhuǎn)載:
Python 緩存機制與 functools.lru_cache


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产精品品福利视频 | 欧美jlzz18性欧美 | 久久国产一片免费观看 | 国产香蕉精品视频在 | 在线观看国产视频 | 狠狠色噜噜狠狠狠8888米奇 | 亚洲国产韩国一区二区 | 国产精选一区二区 | 日日日夜夜操 | 国产乱在线 | 黄黄视频在线观看 | 久久99精品视香蕉蕉 | 亚洲悠悠色综合中文字幕 | 欧美亚洲欧美日韩中文二区 | 国产精品久久久一区二区三区 | 日本a视频在线 | 国产网友自拍 | 色婷婷六月桃花综合影院 | 欧美成人亚洲欧美成人 | 91在线亚洲| 久久综合图区亚洲综合图区 | 色播五月婷婷 | 四虎国产精品永久在线网址 | 国产不卡在线观看视频 | 成人最新午夜免费视频 | 国产精品一区二区三 | 亚洲一区二区三区精品视频 | 中文字幕中文字幕中中文 | 亚洲一区二区欧美日韩 | 91久久香蕉国产线看 | youjizz中国 | 中文字幕一区精品 | 国产精品一区二区在线观看 | 97一区二区三区 | 精品无人区乱码一区2区3区 | 精品视频中文字幕 | 热e国产| 91精品久久久久亚洲国产 | 国产精品videossex激情 | 成人a区| 欧美e片成 人 在线播放乱妇 |