91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

      手機站
      千鋒教育

      千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

      千鋒教育

      掃一掃進入千鋒手機站

      領(lǐng)取全套視頻
      千鋒教育

      關(guān)注千鋒學(xué)習(xí)站小程序
      隨時隨地免費學(xué)習(xí)課程

      當前位置:首頁  >  技術(shù)干貨  > Cache和Buffer都是緩存,主要區(qū)別是什么?

      Cache和Buffer都是緩存,主要區(qū)別是什么?

      來源:千鋒教育
      發(fā)布人:xqq
      時間: 2023-10-11 22:13:28 1697033608

      一、Cache和Buffer都是緩存,主要區(qū)別是什么

      簡單說,Buffer的核心作用是用來緩沖,緩和沖擊。比如你每秒要寫100次硬盤,對系統(tǒng)沖擊很大,浪費了大量時間在忙著處理開始寫和結(jié)束寫這兩件事嘛。用個buffer暫存起來,變成每10秒寫一次硬盤,對系統(tǒng)的沖擊就很小,寫入效率高了,日子過得爽了。極大緩和了沖擊。

      Cache的核心作用是加快取用的速度。比如你一個很復(fù)雜的計算做完了,下次還要用結(jié)果,就把結(jié)果放手邊一個好拿的地方存著,下次不用再算了。加快了數(shù)據(jù)取用的速度。

      所以,如果你注意關(guān)心過存儲系統(tǒng)的話,你會發(fā)現(xiàn)硬盤的讀寫緩沖/緩存名稱是不一樣的,叫write-buffer和read-cache。很明顯地說出了兩者的區(qū)別。

      當然很多時候宏觀上說兩者可能是混用的。比如實際上memcached很多人就是拿來讀寫都用的。不少時候Non-SQL數(shù)據(jù)庫也是。嚴格來說,CPU里的L2和L3 Cache也都是讀寫兼用——因為你沒法簡單地定義CPU用它們的方法是讀還是寫。硬盤里也是個典型例子,buffer和cache都在一塊空間上,到底是buffer還是cache?

      不過仔細想一下,你說拿cache做buffer用行不行?當然行,只要能控制cache淘汰邏輯就沒有任何問題。那么拿buffer做cache用呢?貌似在很特殊的情況下,能確定訪問順序的時候,也是可以的。簡單想一下就明白——buffer根據(jù)定義,需要隨機存儲嗎?一般是不需要的。但cache一定要。所以大多數(shù)時候用cache代替buffer可以,反之就比較局限。這也是技術(shù)上說cache和buffer的關(guān)鍵區(qū)別。

      補充1:不要誤解Buffer就是用來寫的,Cache就是用來讀的。讀可以用Buffer嗎?當然可以,比如你想一批一批地處理讀取而非有啥處理啥的時候,就可以用讀buffer。寫當然也可以用cache,比如你的寫入有很高的隨機性的時候。具體什么場景用Buffer什么場景用Cache要根據(jù)場景的具體需要決定。

      補充2:不要誤解Cache或Buffer就一定是內(nèi)存或者存在什么高速媒介上的東西。只要相對高速即可。我完全可以在硬盤上存Cache,比如有些游戲會在運行時建立預(yù)編譯的shader(暴露年齡),這本質(zhì)上就是一種cache,它存在速度緩慢的硬盤上,因為讀硬盤依舊比重新編譯要快。Buffer也同理,例如NTFS文件系統(tǒng)自己就有Logging Buffer,這個甚至明確拒絕放在任何易失緩存里。

      延伸閱讀:

      二、proc 文件系統(tǒng)

      /proc 是 Linux 內(nèi)核提供的一種特殊文件系統(tǒng),是用戶跟內(nèi)核交互的接口。比方說,用戶可以從 /proc 中查詢內(nèi)核的運行狀態(tài)和配置選項,查詢進程的運行狀態(tài)、統(tǒng)計數(shù)據(jù)等,當然,你也可以通過 /proc 來修改內(nèi)核的配置。

      proc 文件系統(tǒng)同時也是很多性能工具的最終數(shù)據(jù)來源。比如我們剛才看到的 free ,就是通過讀取 /proc/meminfo ,得到內(nèi)存的使用情況。

      繼續(xù)說回 /proc/meminfo,既然 Buffers、Cached、SReclaimable 這幾個指標不容易理解,那我們還得繼續(xù)查 proc 文件系統(tǒng),獲取它們的詳細定義。

      執(zhí)行 man proc ,你就可以得到 proc 文件系統(tǒng)的詳細文檔。注意這個文檔比較長,你較好搜索一下(比如搜索 meminfo),以便更快定位到內(nèi)存部分。

      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
      請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
      免費領(lǐng)取
      今日已有369人領(lǐng)取成功
      劉同學(xué) 138****2860 剛剛成功領(lǐng)取
      王同學(xué) 131****2015 剛剛成功領(lǐng)取
      張同學(xué) 133****4652 剛剛成功領(lǐng)取
      李同學(xué) 135****8607 剛剛成功領(lǐng)取
      楊同學(xué) 132****5667 剛剛成功領(lǐng)取
      岳同學(xué) 134****6652 剛剛成功領(lǐng)取
      梁同學(xué) 157****2950 剛剛成功領(lǐng)取
      劉同學(xué) 189****1015 剛剛成功領(lǐng)取
      張同學(xué) 155****4678 剛剛成功領(lǐng)取
      鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
      董同學(xué) 138****2867 剛剛成功領(lǐng)取
      周同學(xué) 136****3602 剛剛成功領(lǐng)取
      相關(guān)推薦HOT
      mysql inner join為什么不走索引?

      一、mysql inner join為什么不走索引因為索引的優(yōu)勢是在大表中過濾出小的結(jié)果集進行聯(lián)接,mysql inner join句根本沒有任何過濾條件。另外表很小...詳情>>

      2023-10-11 23:07:14
      Geode和redis兩個分布式內(nèi)存數(shù)據(jù)庫的對比,優(yōu)缺點?

      一、Geode和redis兩個分布式內(nèi)存數(shù)據(jù)庫的對比兩者的定位不一樣。Geode是分布式內(nèi)存數(shù)據(jù)庫,提供了可配置的一致性保證,能夠保證數(shù)據(jù)不丟失,更...詳情>>

      2023-10-11 22:50:49
      InnoDB的next-key lock為什么是左開右閉的?

      一、InnoDB的next-key lock為什么是左開右閉的InnoDB的next-key lock本身的設(shè)計方案就是左開右閉的,例如select * from t where c2 = 10 fo詳情>>

      2023-10-11 22:48:02
      到底哪些APP在用Flutter?

      一、滴滴出行滴滴出行是一款出行服務(wù)平臺,提供打車、順風(fēng)車、單車等多種出行方式。在采用Flutter技術(shù)后,滴滴出行成功實現(xiàn)了Android和iOS平臺...詳情>>

      2023-10-11 22:45:35
      web前端和UI前端的區(qū)別?

      一、職責(zé)不同Web前端主要負責(zé)開發(fā)網(wǎng)站的前端部分,通過編寫代碼實現(xiàn)網(wǎng)站的用戶界面和交互功能。而UI前端(也稱為UI設(shè)計師或UI工程師)負責(zé)設(shè)計...詳情>>

      2023-10-11 22:40:09