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

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

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

Buffer和Cache之間區(qū)別是什么?

Dbwd_Imgtec ? 來源:未知 ? 作者:steve ? 2018-04-02 10:35 ? 次閱讀

1 ,buffer(緩沖)

是為了提高內(nèi)存和硬盤(或其他I/O設(shè)備)之間的數(shù)據(jù)交換的速度而設(shè)計的。

2, cache(緩存)

CPU角度考慮,是為了提高cpu和內(nèi)存之間的數(shù)據(jù)交換速度而設(shè)計的,例如平常見到的一級緩存、二級緩存、三級緩存。

cpu在執(zhí)行程序所用的指令和讀數(shù)據(jù)都是針對內(nèi)存的,也就是從內(nèi)存中取得的。由于內(nèi)存讀寫速度慢,為了提高cpu和內(nèi)存之間數(shù)據(jù)交換的速度,在cpu和內(nèi)存之間增加了cache,它的速度比內(nèi)存快,但是造價高,又由于在cpu內(nèi)不能集成太多集成電路,所以一般cache比較小,為了進一步提高速度,又增加了二級cache,甚至三級cache,它是根據(jù)程序的局部性原理而設(shè)計的,就是cpu執(zhí)行的指令和訪問的數(shù)據(jù)往往在集中的某一塊,所以把這塊內(nèi)容放入cache后,cpu就不用在訪問內(nèi)存了,這就提高了訪問速度。當然若cache中沒有cpu所需要的內(nèi)容,還是要訪問內(nèi)存的。

從內(nèi)存讀取與磁盤讀取角度考慮,cache可以理解為操作系統(tǒng)為了更高的讀取效率,更多的使用內(nèi)存來緩存可能被再次訪問的數(shù)據(jù)。

緩沖(buffers)是根據(jù)磁盤的讀寫設(shè)計的,把分散的寫操作集中進行,減少磁盤碎片和硬盤的反復尋道,從而提高系統(tǒng)性能。linux有一個守護進程定期清空緩沖內(nèi)容(即寫入磁盤),也可以通過sync命令手動清空緩沖。

簡單來說,buffer是即將要被寫入磁盤的,而cache是被從磁盤中讀出來的。 buffer是由各種進程分配的,被用在如輸入隊列等方面。一個簡單的例子如某個進程要求有多個字段讀入,在所有字段被讀入完整之前,進程把先前讀入的字段放在buffer中保存。

cache經(jīng)常被用在磁盤的I/O請求上,如果有多個進程都要訪問某個文件,于是該文件便被做成cache以方便下次被訪問,這樣可提高系統(tǒng)性能。

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

    關(guān)注

    68

    文章

    10863

    瀏覽量

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

    關(guān)注

    1

    文章

    240

    瀏覽量

    26679

原文標題:Buffer和Cache之間區(qū)別是什么?

文章出處:【微信號:Imgtec,微信公眾號:Imagination Tech】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    請問MSP430各型號之間區(qū)別是什么?

    哪位用過MSP430各型號之間區(qū)別是什么最近在用MSP430單片機,他們型號很多,知不知道他們之間區(qū)別是什么比如MSP430F149與MSP430F2274
    發(fā)表于 04-16 06:35

    EDIT和NGC文件之間區(qū)別是什么?

    EDIF文件和NGC文件之間的基本區(qū)別是什么?這兩個文件類型都指定netlist?那么微妙的差異是什么呢?以上來自于谷歌翻譯以下為原文What is the basic difference
    發(fā)表于 05-23 10:13

    Cache機制的原理是什么?

    的高速度。CPU與外設(shè)交換數(shù)據(jù)時經(jīng)常用到buffer(緩沖),這與緩存極其相似,只不過Cache是為了提高CPU和內(nèi)存之間的數(shù)據(jù)交換速度而設(shè)計,而buffer是為了提高內(nèi)存和硬盤(或其
    發(fā)表于 10-12 06:01

    芯片和集成電路之間區(qū)別是什么

    `  誰來闡述一下芯片和集成電路之間區(qū)別是什么?`
    發(fā)表于 03-24 17:15

    GPRS模塊和GSM模塊之間區(qū)別是什么?

    GPRS模塊和GSM模塊之間區(qū)別是什么?
    發(fā)表于 06-22 06:31

    mes系統(tǒng)和erp系統(tǒng)之間區(qū)別是什么?

    WHAT-MES是什么?WHY-為什么上MES?常見MES的模塊有哪些?mes系統(tǒng)和erp系統(tǒng)之間區(qū)別是什么?
    發(fā)表于 09-18 07:11

    mCAN、msCAN和FlexCAN之間區(qū)別是什么?

    我不明白 mCAN、msCAN 和 FlexCAN 之間區(qū)別是什么,或者為什么存在這么多不同版本的 can 外設(shè)。 是否有關(guān)于每個產(chǎn)品的文檔?
    發(fā)表于 03-29 08:19

    詳談嵌入式編程需注意的Cache機制和原理

    盡可能發(fā)揮CPU的高速度。CPU與外設(shè)交換數(shù)據(jù)時經(jīng)常用到buffer(緩沖),這與緩存極其相似,只不過Cache是為了提高CPU和內(nèi)存之間的數(shù)據(jù)交換速度而設(shè)計,而buffer是為了提高
    發(fā)表于 11-01 16:16 ?0次下載
    詳談嵌入式編程需注意的<b class='flag-5'>Cache</b>機制和原理

    寄存器和cache區(qū)別介紹

    本文開始闡述了CACHE的概念、CACHE替換機構(gòu)與讀寫操作,其次介紹了寄存器的原理以及它的主要技術(shù),最后闡述了寄存器和cache兩者之間區(qū)別
    發(fā)表于 04-11 14:10 ?1.3w次閱讀

    Linux內(nèi)核Page CacheBuffer Cache兩類緩存的作用及關(guān)系如何

    page)即為頁緩存(page cache)。塊緩存(buffer cache),則是內(nèi)核為了加速對底層存儲介質(zhì)的訪問速度,而構(gòu)建的一層緩存。
    的頭像 發(fā)表于 07-02 14:25 ?2766次閱讀
    Linux內(nèi)核Page <b class='flag-5'>Cache</b>和<b class='flag-5'>Buffer</b> <b class='flag-5'>Cache</b>兩類緩存的作用及關(guān)系如何

    BufferCache的定義

    但是讓我問你,由于 Buffer 只是將寫入磁盤的數(shù)據(jù)的緩存。反過來,它還會緩存從磁盤讀取的數(shù)據(jù)嗎?或者 Cache 是從文件中讀取數(shù)據(jù)的緩存,那么它是否也為寫入文件緩存數(shù)據(jù)呢?
    的頭像 發(fā)表于 05-13 09:53 ?2074次閱讀

    Buffercache區(qū)別

    Bbuffer 與 Cache 非常類似,因為它們都用于存儲數(shù)據(jù)數(shù)據(jù),被應(yīng)用層讀取字節(jié)數(shù)據(jù)。
    的頭像 發(fā)表于 07-01 10:44 ?3905次閱讀

    BufferCache介紹

    設(shè)計的目的就是當上面提到的+buffers/cache表示的可用內(nèi)存都已使用完,新的讀寫請求過來后,會把內(nèi)存中的部分數(shù)據(jù)寫入磁盤,從而把磁盤的部分空間當做虛擬內(nèi)存來使用。
    的頭像 發(fā)表于 08-18 09:50 ?1252次閱讀

    buffercache區(qū)別

    buffercache區(qū)別 緩沖區(qū)(Buffer)和緩存(Cache)是計算機系統(tǒng)中用于提高數(shù)據(jù)讀寫效率的兩個關(guān)鍵概念,它們雖然功能有所
    的頭像 發(fā)表于 12-07 11:00 ?857次閱讀

    Cache和內(nèi)存有什么區(qū)別

    Cache(高速緩存)和內(nèi)存(Memory,通常指主存儲器或RAM)是計算機存儲系統(tǒng)中兩個重要的組成部分,它們在計算機的性能和數(shù)據(jù)處理中扮演著不同的角色。以下是對Cache和內(nèi)存之間區(qū)別
    的頭像 發(fā)表于 09-26 15:28 ?1565次閱讀