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

主頁 > 知識庫 > python自帶緩存lru_cache用法及擴(kuò)展的使用

python自帶緩存lru_cache用法及擴(kuò)展的使用

熱門標(biāo)簽:南昌地圖標(biāo)注 西青語音電銷機(jī)器人哪家好 無錫智能外呼系統(tǒng)好用嗎 宿州電話機(jī)器人哪家好 電梯新時達(dá)系統(tǒng)外呼顯示e 旅游廁所地圖標(biāo)注怎么弄 地圖標(biāo)注與注銷 百應(yīng)電話機(jī)器人總部 成都呼叫中心外呼系統(tǒng)哪家強(qiáng)

本篇博客將結(jié)合python官方文檔和源碼詳細(xì)講述lru_cache緩存方法是怎么實(shí)現(xiàn), 它與redis緩存的區(qū)別是什么, 在使用時碰上functiontools.wrap裝飾器時會發(fā)生怎樣的變化,以及了解它給我們提供了哪些功能然后在其基礎(chǔ)上實(shí)現(xiàn)我們自制的緩存方法my_cache。

1. lru_cache的使用

1.1 參數(shù)詳解

以下是lru_cache方法的實(shí)現(xiàn),我們看出可供我們傳入的參數(shù)有2個maxsize和typed,如果不傳則maxsize的默認(rèn)值為128,typed的默認(rèn)值為False。其中maxsize參數(shù)表示是的被裝飾的方法最大可緩存結(jié)果數(shù)量, 如果是默認(rèn)值128則表示被裝飾方法最多可緩存128個返回結(jié)果,如果maxsize傳入為None則表示可以緩存無限個結(jié)果,你可能會疑惑被裝飾方法的n個結(jié)果是怎么來的,打個比方被裝飾的方法為def add(a, b):當(dāng)函數(shù)被lru_cache裝飾時,我們調(diào)用add(1, 2)和add(3, 4)將會緩存不同的結(jié)果。如果 typed 設(shè)置為true,不同類型的函數(shù)參數(shù)將被分別緩存。例如, f(3) 和 f(3.0) 將被視為不同而分別緩存。

def lru_cache(maxsize=128, typed=False):
    if isinstance(maxsize, int):
        if maxsize  0:
            maxsize = 0
    elif maxsize is not None:
        raise TypeError('Expected maxsize to be an integer or None')

    def decorating_function(user_function):
        wrapper = _lru_cache_wrapper(user_function, maxsize, typed, _CacheInfo)
        return update_wrapper(wrapper, user_function)

    return decorating_function

1.2 基本用法

在我們編寫接口時可能需要緩存一些變動不大的數(shù)據(jù)如配置信息,我們可能編寫如下接口:

@api.route("/user/info", methods=["GET"])
@functools.lru_cache()
@login_require
def get_userinfo_list():
    userinfos = UserInfo.query.all()
    userinfo_list = [user.to_dict() for user in userinfos]
    return jsonify(userinfo_list)

我們緩存了從數(shù)據(jù)庫查詢的用戶信息,下次再調(diào)用這個接口時將直接返回用戶信息列表而不需要重新執(zhí)行一遍數(shù)據(jù)庫查詢邏輯,可以有效較少IO次數(shù),加快接口反應(yīng)速度。

1.3 進(jìn)階用法

還是以上面的例子,如果發(fā)生用戶的刪除或者新增時,我們再請求用戶接口時仍然返回的是緩存中的數(shù)據(jù),這樣返回的信息就和我們數(shù)據(jù)庫中的數(shù)據(jù)就會存在差異,所以當(dāng)發(fā)生用戶新增或者刪除時,我們需要清除原先的緩存,然后再請求用戶接口時可以重新加載緩存。

@api.route("/user/info", methods=["POST"])
@functools.lru_cache()
@login_require
def add_user():
    user = UserInfo(name="李四")
    db.session.add(user)
    db.session.commit()
    
    # 清除get_userinfo_list中的緩存
    get_userinfo_list = current_app.view_functions["api.get_machine_list"]
    cache_info = get_userinfo_list.cache_info()
    # cache_info 具名元組,包含命中次數(shù) hits,未命中次數(shù) misses ,最大緩存數(shù)量 maxsize 和 當(dāng)前緩存大小 currsize
    # 如果緩存數(shù)量大于0則清除緩存
    if cache_info[3] > 0:
     get_userinfo_list.cache_clear()
    return jsonify("新增用戶成功")

在上面這個用法中我們,如果我們把lru_cache裝飾器和login_require裝飾器調(diào)換位置時,上述的寫法將會報錯,這是因?yàn)閘ogin_require裝飾器中用了functiontools.wrap模塊進(jìn)行裝飾導(dǎo)致的,具原因我們在下節(jié)解釋, 如果想不報錯得修改成如下寫法。

@api.route("/user/info", methods=["POST"])
@login_require
@functools.lru_cache()
def add_user():
    user = UserInfo(name="李四")
    db.session.add(user)
    db.session.commit()
    
    # 清除get_userinfo_list中的緩存
    get_userinfo_list = current_app.view_functions["api.get_machine_list"]
    cache_info = get_userinfo_list.__wrapped__.cache_info()
    # cache_info 具名元組,包含命中次數(shù) hits,未命中次數(shù) misses ,最大緩存數(shù)量 maxsize 和 當(dāng)前緩存大小 currsize
    # 如果緩存數(shù)量大于0則清除緩存
    if cache_info[3] > 0:
     get_userinfo_list.__wrapped__.cache_clear()
    return jsonify("新增用戶成功")

2. functiontools.wrap裝飾器對lru_cache的影響

在上節(jié)我們看到,因?yàn)锧login_require和@functools.lru_cache()裝飾器的順序不同, 就導(dǎo)致了程序是否報錯, 其中主要涉及到兩點(diǎn):

  • login_require裝飾器中是否用了@functiontools.wrap()裝飾器
  • @login_require和@functools.lru_cache()裝飾器的執(zhí)行順序問題

當(dāng)我們了解完這兩點(diǎn)后就可以理解上述寫法了。

2.1 多個裝飾器裝飾同一函數(shù)時的執(zhí)行順序

這里從其他地方盜了一段代碼來解釋一下,如下:

def decorator_a(func):
    print('Get in decorator_a')
    def inner_a(*args,**kwargs):
        print('Get in inner_a')
        res = func(*args,**kwargs)
        return res
    return inner_a

def decorator_b(func):
    print('Get in decorator_b')
    def inner_b(*args,**kwargs):
        print('Get in inner_b')
        res = func(*args,**kwargs)
        return res
    return inner_b


@decorator_b
@decorator_a
def f(x):
    print('Get in f')
    return x * 2

f(1)

輸出結(jié)果如下:

'Get in decorator_a'
'Get in decorator_b'
'Get in inner_b'
'Get in inner_a'
'Get in f'

是不是很像django中的中間件的執(zhí)行順序,其實(shí)原理都差不多。

2.2 functiontools.wrap原理

引用其他博主的描述:

Python裝飾器(decorator)在實(shí)現(xiàn)的時候,被裝飾后的函數(shù)其實(shí)已經(jīng)是另外一個函數(shù)了(函數(shù)名等函數(shù)屬性會發(fā)生改變),為了不影響,Python的functools包中提供了一個叫wraps的decorator來消除這樣的副作用。寫一個decorator的時候,最好在實(shí)現(xiàn)之前加上functools的wrap,它能保留原有函數(shù)的名稱和docstring。

補(bǔ)充:為了訪問原函數(shù)此函數(shù)會設(shè)置一個__wrapped__屬性指向原函數(shù), 這樣就可以解釋上面1.3節(jié)中我們的寫法了。

2.3 使用wrap裝飾器前后的變化

未完待續(xù)。。。。。。。。。

3. 自制簡易的my_cache

3.1 lru_cache提供的功能

lru_cache緩存裝飾器提供的功能有:

  • 緩存被裝飾對象的結(jié)果(基礎(chǔ)功能)
  • 獲取緩存信息
  • 清除緩存內(nèi)容
  • 根據(jù)參數(shù)變化緩存不同的結(jié)果
  • LRU算法當(dāng)緩存數(shù)量大于設(shè)置的maxsize時清除最不常使用的緩存結(jié)果

​ 從列出的功能可知,python自帶的lru_cache緩存方法可以滿足我們?nèi)粘9ぷ髦写蟛糠中枨螅?可是它不包含一個重要的特性就是,超時自動刪除緩存結(jié)果,所以在我們自制的my_cache中我們將實(shí)現(xiàn)緩存的超時過期功能。

3.2 cache的核心部件

在作用域內(nèi)存在一個相對全局的字典變量cache={}

在作用域內(nèi)設(shè)置相對全局的變量包含命中次數(shù) hits,未命中次數(shù) misses ,最大緩存數(shù)量 maxsize和 當(dāng)前緩存大小 currsize

第二點(diǎn)中的緩存信息中增加緩存加入時間和緩存有效時間

3.3 my_cache的實(shí)現(xiàn)

待實(shí)現(xiàn)。。。。。。。。。。。。

4. lru_cache緩存和redis緩存的區(qū)別

比較類型 lru_cache redis
緩存類型 緩存在app進(jìn)程內(nèi)存中 緩存在redis管理的內(nèi)存中
分布式 只緩存在單個app進(jìn)程中 可做分布式緩存
數(shù)據(jù)類型 hash 參數(shù)作為key,返回結(jié)果為value 有5種類型的數(shù)據(jù)結(jié)構(gòu)
適用場景 比較小型的系統(tǒng)、單體應(yīng)用 常用的緩存解決方案
功能 緩存功能但是缺少過期時間控制,但是使用上更加便捷 具備緩存需要的各種要素

5. 總結(jié)

綜上所述,python自帶的緩存功能使用于稍微小型的單體應(yīng)用。優(yōu)點(diǎn)是可以很方便的根據(jù)傳入不同的參數(shù)緩存對應(yīng)的結(jié)果, 并且可以有效控制緩存的結(jié)果數(shù)量,在超過設(shè)置數(shù)量時根據(jù)LRU算法淘汰命中次數(shù)最少的緩存結(jié)果。缺點(diǎn)是沒有辦法對緩存過期時間進(jìn)行設(shè)置。

到此這篇關(guān)于python自帶緩存lru_cache用法及擴(kuò)展的使用的文章就介紹到這了,更多相關(guān)python自帶緩存lru_cache內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python 的lru_cache裝飾器使用簡介
  • Python中l(wèi)ru_cache的使用和實(shí)現(xiàn)詳解
  • Python實(shí)現(xiàn)的一個簡單LRU cache

標(biāo)簽:濰坊 許昌 西安 渭南 七臺河 贛州 雅安 辛集

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python自帶緩存lru_cache用法及擴(kuò)展的使用》,本文關(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用法及擴(kuò)展的使用》相關(guān)的同類信息!
  • 本頁收集關(guān)于python自帶緩存lru_cache用法及擴(kuò)展的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章

    上一篇:python 使用GDAL實(shí)現(xiàn)柵格tif轉(zhuǎn)矢量shp的方式小結(jié)

    下一篇:python3之Splash的具體使用

    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久精品免费在线观看| 亚洲成人先锋电影| 一区二区三区在线视频观看58| 亚洲成国产人片在线观看| 国产综合色视频| 精品国产乱码久久久久久浪潮| 26uuu精品一区二区三区四区在线| 中文字幕一区二区在线观看| 国产一区二区美女| 欧美日韩亚洲国产综合| 日韩一区中文字幕| 国产精品一区专区| 欧美三级三级三级爽爽爽| 国产精品免费久久| 国产一区二区视频在线播放| 日韩欧美久久久| 水蜜桃久久夜色精品一区的特点| 色综合久久综合网| 亚洲欧美电影一区二区| 成人av网站免费观看| 久久天天做天天爱综合色| 午夜在线电影亚洲一区| 色婷婷精品大在线视频| 亚洲欧美在线aaa| 国产很黄免费观看久久| xvideos.蜜桃一区二区| 麻豆91在线观看| 精品久久一二三区| 国精产品一区一区三区mba视频 | 欧美国产一区视频在线观看| 青青草国产精品亚洲专区无| 欧美一级专区免费大片| 亚洲图片欧美综合| 日韩毛片高清在线播放| 国产欧美日韩麻豆91| 麻豆精品一区二区三区| 日韩精品一区二区三区蜜臀| 亚洲第一福利视频在线| 国产亚洲婷婷免费| 欧美日韩不卡一区| 99国产精品国产精品久久| 日本欧美韩国一区三区| 亚洲色图制服丝袜| 精品理论电影在线| 欧美日韩国产精品自在自线| 国产a级毛片一区| 青青国产91久久久久久| 亚洲国产aⅴ成人精品无吗| 国产日本欧洲亚洲| 91精品国产黑色紧身裤美女| 91麻豆精品在线观看| 久久疯狂做爰流白浆xx| 天天综合网天天综合色| 亚洲日本在线观看| 国产拍欧美日韩视频二区| 91麻豆精品国产91久久久资源速度| 国产成人免费高清| 国产剧情一区二区三区| 日韩av高清在线观看| 亚洲午夜日本在线观看| 综合欧美亚洲日本| 中文字幕欧美激情| 久久久久99精品一区| 精品国产伦一区二区三区观看方式 | 亚洲欧美欧美一区二区三区| 久久嫩草精品久久久久| 69p69国产精品| 欧美视频一区二区三区在线观看| 91激情五月电影| 在线免费亚洲电影| 一道本成人在线| 在线观看一区日韩| 欧美在线免费视屏| 欧美影视一区在线| 欧美性欧美巨大黑白大战| 91精品91久久久中77777| 日本韩国欧美一区二区三区| 91网站在线观看视频| 99精品视频在线观看| 91在线小视频| 色噜噜久久综合| 欧美欧美欧美欧美首页| 欧美高清视频不卡网| 日韩欧美久久一区| 久久久午夜精品理论片中文字幕| 久久亚洲精精品中文字幕早川悠里| 精品国产91九色蝌蚪| 国产色91在线| 亚洲精品v日韩精品| 亚洲国产一区二区三区青草影视| 亚洲成人先锋电影| 麻豆91免费看| 国产不卡免费视频| 色婷婷精品久久二区二区蜜臂av| 欧美乱妇15p| 国产欧美精品区一区二区三区 | 麻豆成人91精品二区三区| 国产在线精品免费| 国产 欧美在线| 在线中文字幕不卡| 日韩欧美一二三区| 国产精品网曝门| 亚洲图片一区二区| 国内外成人在线| 色综合色综合色综合色综合色综合 | 欧美激情一区二区三区全黄| 亚洲婷婷国产精品电影人久久| 一区二区三区产品免费精品久久75| 亚洲国产精品久久一线不卡| 免费av成人在线| 成人激情av网| 欧美高清视频一二三区| 国产精品欧美一级免费| 亚洲国产成人精品视频| 国产精品1024久久| 欧美日本高清视频在线观看| 26uuu亚洲综合色| 一区二区三区四区激情| 国产一区二区三区四区五区入口| 色综合久久六月婷婷中文字幕| 欧美岛国在线观看| 亚洲午夜久久久久中文字幕久| 狠狠久久亚洲欧美| 欧美日韩电影在线| 亚洲色图视频网站| 国产精品一区二区在线看| 欧美色老头old∨ideo| 欧美激情一区二区三区不卡| 日韩精品亚洲一区| 在线一区二区视频| 国产精品理论在线观看| 精品中文字幕一区二区| 欧美日韩精品三区| 一区二区三区在线观看网站| 国产精品2024| 欧美一区二区成人6969| 亚洲国产成人av好男人在线观看| 成人一区二区三区在线观看| 精品蜜桃在线看| 日韩**一区毛片| 欧美日韩国产三级| 亚洲乱码国产乱码精品精98午夜 | 国产日韩精品一区二区三区在线| 青青草97国产精品免费观看| 欧美三区在线视频| 自拍偷自拍亚洲精品播放| 国产成人午夜精品影院观看视频 | 久久在线免费观看| 日韩成人av影视| 欧美日韩视频不卡| 夜夜揉揉日日人人青青一国产精品| 国产寡妇亲子伦一区二区| 久久综合九色综合久久久精品综合| 日本中文字幕一区二区有限公司| 欧美午夜一区二区| 一区二区三区四区不卡视频| 91久久香蕉国产日韩欧美9色| 亚洲国产精品99久久久久久久久| 国产乱码字幕精品高清av| 精品久久久久久久久久久久包黑料 | 午夜精品久久久久久久久| 欧美视频一区二区三区| 亚洲一级二级在线| 欧美色综合网站| 亚洲超碰精品一区二区| 欧美性大战久久久久久久蜜臀| 一区二区三区四区亚洲| 欧美无砖专区一中文字| 亚洲成av人片在线观看| 欧美日韩精品一区二区| 日韩不卡一区二区| 日韩欧美成人一区二区| 国产美女一区二区| 国产无一区二区| 99精品在线观看视频| 亚洲一区二区欧美日韩| 欧美男女性生活在线直播观看| 三级在线观看一区二区| 欧美tickling网站挠脚心| 韩国精品主播一区二区在线观看| 久久久久久久性| 成年人网站91| 亚洲综合激情另类小说区| 欧美日本在线播放| 美日韩黄色大片| 欧美经典一区二区三区| 99国产精品一区| 日韩**一区毛片| 中文字幕巨乱亚洲| 精品视频色一区| 精品一二三四区| 国产人妖乱国产精品人妖| 日本精品免费观看高清观看| 日本欧美加勒比视频| 欧美国产一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 91麻豆精品国产91久久久久| 国产一区福利在线| 亚洲色图一区二区| 欧美成人bangbros|