chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一文理解python模塊的緩存

python爬蟲知識分享 ? 來源:python爬蟲知識分享 ? 作者:python爬蟲知識分享 ? 2022-03-14 16:42 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在一個模塊內(nèi)部重復引用另一個相同模塊,實際并不會導入兩次,原因是在使用關(guān)鍵字 import 導入模塊時,它會先檢索 sys.modules 里是否已經(jīng)載入這個模塊了,如果已經(jīng)載入,則不會再次導入,如果不存在,才會去檢索導入這個模塊。

來實驗一下,在 my_mod02 這個模塊里,我 import 兩次 my_mod01 這個模塊,按邏輯每一次 import 會一次 my_mod01 里的代碼(即打印 in mod01),但是驗證結(jié)果是,只打印了一次。

$ cat my_mod01.py
print('in mod01')

$ cat my_mod02.py
import my_mod01
import my_mod01

$ python my_mod02.py
in mod01

該現(xiàn)象的解釋是:因為有 sys.modules 的存在。

sys.modules 是一個字典(key:模塊名,value:模塊對象),它存放著在當前 namespace 所有已經(jīng)導入的模塊對象。

# test_module.py

import sys
print(sys.modules.get('json', 'NotFound'))

import json
print(sys.modules.get('json', 'NotFound'))

運行結(jié)果如下,可見在 導入后 json 模塊后,sys.modules 才有了 json 模塊的對象。

$ python test_module.py
NotFound

由于有緩存的存在,使得我們無法重新載入一個模塊。

但若你想反其道行之,可以借助 importlib 這個神奇的庫來實現(xiàn)。事實也確實有此場景,比如在代碼調(diào)試中,在發(fā)現(xiàn)代碼有異常并修改后,我們通常要重啟服務(wù)再次載入程序。這時候,若有了模塊重載,就無比方便了,修改完代碼后也無需服務(wù)的重啟,就能繼續(xù)調(diào)試。

還是以上面的例子來理解,my_mod02.py 改寫成如下

# my_mod02.py

import importlib
import my_mod01
importlib.reload(my_mod01)

與上面不同的是,這邊執(zhí)行了兩次 my_mod01.py

$ python3 my_mod02.py
in mod01
in mod01

審核編輯:湯梓紅
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 模塊
    +關(guān)注

    關(guān)注

    7

    文章

    2820

    瀏覽量

    52770
  • 緩存
    +關(guān)注

    關(guān)注

    1

    文章

    248

    瀏覽量

    27635
  • python
    +關(guān)注

    關(guān)注

    57

    文章

    4856

    瀏覽量

    89520
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    電能表會 “爆表” 嗎?機械 / 家用 / 快充樁場景的計量真相拆解

    文理清:為何家用電表難 “爆表”,快充樁卻會?
    的頭像 發(fā)表于 11-12 09:25 ?815次閱讀
    電能表會 “爆表” 嗎?機械 / 家用 / 快充樁場景的計量真相拆解

    文理解模數(shù)轉(zhuǎn)換器中的有效位數(shù)

    隨著測量精度要求提升,有效位數(shù)(ENOB)已成為評估ADC、數(shù)字示波器真實性能的核心指標。ENOB由IEEE定義,綜合了噪聲、抖動、非線性失真等誤差,反映設(shè)備在實際使用中的“有效分辨率”。
    的頭像 發(fā)表于 10-09 11:01 ?2710次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文理解</b>模數(shù)轉(zhuǎn)換器中的有效位數(shù)

    詳解xilinx 7系列FPGA配置技巧

    本文旨在通過講解不同模式的原理圖連接方式,進而配置用到引腳的含義(手冊上相關(guān)引腳含義有四、五頁,通過本文理解基本上能夠記住所有引腳含義以及使用場景),熟悉xilinx 7系列配置流程,以及設(shè)計原理圖時需要注意的些事項,比如flash與FPGA的上電時序。
    的頭像 發(fā)表于 08-30 14:35 ?8788次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>詳解xilinx 7系列FPGA配置技巧

    緩存之美:萬詳解 Caffeine 實現(xiàn)原理(上)

    文章將采用“總-分-總”的結(jié)構(gòu)對配置固定大小元素驅(qū)逐策略的 Caffeine 緩存進行介紹,首先會講解它的實現(xiàn)原理,在大家對它有個概念之后再深入具體源碼的細節(jié)之中,理解它的設(shè)計理念,從中能學習到
    的頭像 發(fā)表于 08-05 14:49 ?507次閱讀
    <b class='flag-5'>緩存</b>之美:萬<b class='flag-5'>文</b>詳解 Caffeine 實現(xiàn)原理(上)

    高性能緩存設(shè)計:如何解決緩存偽共享問題

    在多核高并發(fā)場景下, 緩存偽共享(False Sharing) 是導致性能驟降的“隱形殺手”。當不同線程頻繁修改同緩存行(Cache Line)中的獨立變量時,CPU緩存
    的頭像 發(fā)表于 07-01 15:01 ?487次閱讀
    高性能<b class='flag-5'>緩存</b>設(shè)計:如何解決<b class='flag-5'>緩存</b>偽共享問題

    由 Mybatis 源碼暢談軟件設(shè)計(八):從根上理解 Mybatis 二級緩存

    1. 驗證二級緩存 在上篇帖子中的 User 和 Department 實體類依然要用,這里就不再贅述了,要啟用二級緩存,需要在 Mapper.xml 文件中指定 cache 標簽,如下
    的頭像 發(fā)表于 06-23 11:35 ?314次閱讀
    由 Mybatis 源碼暢談軟件設(shè)計(八):從根上<b class='flag-5'>理解</b> Mybatis 二級<b class='flag-5'>緩存</b>

    MCU緩存設(shè)計

    MCU 設(shè)計通過優(yōu)化指令與數(shù)據(jù)的訪問效率,顯著提升系統(tǒng)性能并降低功耗,其核心架構(gòu)與實現(xiàn)策略如下: 、緩存類型與結(jié)構(gòu) 指令緩存(I-Cache)與數(shù)據(jù)緩存(D-Cache)? I-Ca
    的頭像 發(fā)表于 05-07 15:29 ?815次閱讀

    Nginx緩存配置詳解

    Nginx 是個功能強大的 Web 服務(wù)器和反向代理服務(wù)器,它可以用于實現(xiàn)靜態(tài)內(nèi)容的緩存,緩存可以分為客戶端緩存和服務(wù)端緩存
    的頭像 發(fā)表于 05-07 14:03 ?1025次閱讀
    Nginx<b class='flag-5'>緩存</b>配置詳解

    nginx中強緩存和協(xié)商緩存介紹

    緩存直接告訴瀏覽器:在緩存過期前,無需與服務(wù)器通信,直接使用本地緩存。
    的頭像 發(fā)表于 04-01 16:01 ?712次閱讀

    運行OVModelForCausalLM Python模塊時出錯了,怎么解決?

    創(chuàng)建了個自定義 Python* 代碼,類似于遵循 240-dolly-2-instruction 的 Jupyter 筆記本。 OVModelForCausalLM Python*
    發(fā)表于 03-05 06:44

    緩存與不帶緩存的固態(tài)硬盤有什么區(qū)別

    延遲、高可靠性和低噪音等優(yōu)點,逐漸取代了傳統(tǒng)的機械硬盤,成為市場的主流選擇。而固態(tài)硬盤中的緩存技術(shù),更是提升其性能的關(guān)鍵因素之。本文將深入探討固態(tài)硬盤的定義、結(jié)構(gòu)、工作原理,以及帶緩存與不帶
    的頭像 發(fā)表于 02-06 16:35 ?4217次閱讀

    HTTP緩存頭的使用 本地緩存與遠程緩存的區(qū)別

    HTTP緩存頭是組HTTP響應(yīng)頭,它們控制瀏覽器和中間代理服務(wù)器如何緩存網(wǎng)頁內(nèi)容。合理使用HTTP緩存頭可以顯著提高網(wǎng)站的加載速度和性能,減少服務(wù)器的負載。 1. HTTP
    的頭像 發(fā)表于 12-18 09:41 ?801次閱讀

    什么是緩存(Cache)及其作用

    緩存(Cache)是種高速存儲器,用于臨時存儲數(shù)據(jù),以便快速訪問。在計算機系統(tǒng)中,緩存的作用是減少處理器訪問主存儲器(如隨機存取存儲器RAM)所需的時間。 緩存(Cache)概述
    的頭像 發(fā)表于 12-18 09:28 ?1.5w次閱讀

    文理解多模態(tài)大語言模型——下

    /understanding-multimodal-llms ? 《文理解多模態(tài)大語言模型 - 上》介紹了什么是多模態(tài)大語言模型,以及構(gòu)建多模態(tài) LLM 有兩種主要方式之:統(tǒng)嵌入
    的頭像 發(fā)表于 12-03 15:18 ?968次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文理解</b>多模態(tài)大語言模型——下

    文理解多模態(tài)大語言模型——上

    利于中文讀者理解的目標,做了刪減、重構(gòu)和意譯,并替換了多張不適合中文讀者的示意圖。 原文地址:https://magazine.sebastianraschka.com/p
    的頭像 發(fā)表于 12-02 18:29 ?1913次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文理解</b>多模態(tài)大語言模型——上