點(diǎn)擊上方“開源Linux”,選擇“設(shè)為星標(biāo)”
回復(fù)“學(xué)習(xí)”獲取獨(dú)家整理的學(xué)習(xí)資料!
這是本人見過對 Cache 和 Buffer 的區(qū)別最直觀的圖文解釋,讓人一目了然。
問題:Cache 和 Buffer 都是緩存,主要區(qū)別是什么?倆英文單詞,不先看看本意嗎?雖然都是抽象單詞,但在各個(gè)地方都有具象的應(yīng)用。
對,就是鐵道端頭那個(gè)巨大的彈簧一類的東西。作用是萬一車沒停?。ㄊ菦]停住啊,剎車了但是差一點(diǎn)沒剎住那種,不是不拉剎直接撞上來),撞彈簧上減速慢,危險(xiǎn)小一些。叫緩沖。沒錯(cuò),就是一種保管箱??吹接疫吥莻€(gè)被銹掉的Food Cache沒?這是部署在森林里的存應(yīng)急物資的保管箱。功能是把你需要用的東西放在更容易拿到的地方。雖然常用準(zhǔn)確翻譯叫緩存,但個(gè)人以為意思表達(dá)的不對,丟了一半的功能。臺(tái)灣的翻譯更好,叫快取。相信看完這些應(yīng)該不用我說區(qū)別了?簡單說,Buffer的核心作用是用來緩沖,緩和沖擊。比如你每秒要寫100次硬盤,對系統(tǒng)沖擊很大,浪費(fèi)了大量時(shí)間在忙著處理開始寫和結(jié)束寫這兩件事嘛。用個(gè)buffer暫存起來,變成每10秒寫一次硬盤,對系統(tǒng)的沖擊就很小,寫入效率高了,日子過得爽了。極大緩和了沖擊。Cache的核心作用是加快取用的速度。比如你一個(gè)很復(fù)雜的計(jì)算做完了,下次還要用結(jié)果,就把結(jié)果放手邊一個(gè)好拿的地方存著,下次不用再算了。加快了數(shù)據(jù)取用的速度。所以,如果你注意關(guān)心過存儲(chǔ)系統(tǒng)的話,你會(huì)發(fā)現(xiàn)硬盤的讀寫緩沖/緩存名稱是不一樣的,叫write-buffer和read-cache。很明顯地說出了兩者的區(qū)別。當(dāng)然很多時(shí)候宏觀上說兩者可能是混用的。比如實(shí)際上memcached很多人就是拿來讀寫都用的。不少時(shí)候Non-SQL數(shù)據(jù)庫也是。嚴(yán)格來說,CPU里的L2和L3 Cache也都是讀寫兼用——因?yàn)槟銢]法簡單地定義CPU用它們的方法是讀還是寫。硬盤里也是個(gè)典型例子,buffer和cache都在一塊空間上,到底是buffer還是cache?不過仔細(xì)想一下,你說拿cache做buffer用行不行?當(dāng)然行,只要能控制cache淘汰邏輯就沒有任何問題。那么拿buffer做cache用呢?貌似在很特殊的情況下,能確定訪問順序的時(shí)候,也是可以的。簡單想一下就明白——buffer根據(jù)定義,需要隨機(jī)存儲(chǔ)嗎?一般是不需要的。但cache一定要。所以大多數(shù)時(shí)候用cache代替buffer可以,反之就比較局限。這也是技術(shù)上說cache和buffer的關(guān)鍵區(qū)別。
補(bǔ)充1:不要誤解Buffer就是用來寫的,Cache就是用來讀的。讀可以用Buffer嗎?當(dāng)然可以,比如你想一批一批地處理讀取而非有啥處理啥的時(shí)候,就可以用讀buffer。寫當(dāng)然也可以用cache,比如你的寫入有很高的隨機(jī)性的時(shí)候。具體什么場景用Buffer什么場景用Cache要根據(jù)場景的具體需要決定。補(bǔ)充2:不要誤解Cache或Buffer就一定是內(nèi)存或者存在什么高速媒介上的東西。只要相對高速即可。我完全可以在硬盤上存Cache,比如有些游戲會(huì)在運(yùn)行時(shí)建立預(yù)編譯的shader(暴露年齡),這本質(zhì)上就是一種cache,它存在速度緩慢的硬盤上,因?yàn)樽x硬盤依舊比重新編譯要快。Buffer也同理,例如NTFS文件系統(tǒng)自己就有Logging Buffer,這個(gè)甚至明確拒絕放在任何易失緩存里。原文:https://urlify.cn/Ibiu2a
作者:沈萬馬關(guān)注「開源Linux」加星標(biāo),提升IT技能