色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

操作系統(tǒng)不同的緩沖區(qū)概念

科技綠洲 ? 來源:Linux開發(fā)架構(gòu)之路 ? 作者:Linux開發(fā)架構(gòu)之路 ? 2023-11-10 10:38 ? 次閱讀

常常聽到有程序員會跟你討論:“我們在讀寫文件的時候,系統(tǒng)是有緩存的”。但實際上有一部分人把用戶進程緩存區(qū)和系統(tǒng)空間緩存區(qū)的概念混淆了,包括這兩種緩沖區(qū)的用法和所要解決的問題,還有其它類似的概念。本文就來區(qū)分一下不同的緩沖區(qū)概念(主要針對類unix平臺)。

用戶進程和操作系統(tǒng)的關(guān)系,首先我用一張圖來解釋“用戶進程和操作系統(tǒng)的關(guān)系:

圖片

這是一個計算機系統(tǒng)運行時的簡化模型,我們把所有運行在操作系統(tǒng)上的進程成為用戶進程,它們都運行在用戶空間(可以看到用戶空間有很多進程)。把操作系統(tǒng)運行的空間成為系統(tǒng)空間。

為什么將進程分為用戶進程和系統(tǒng)進程,首先你一定聽說過內(nèi)核態(tài)和用戶態(tài)(kernel mode和user mode),在內(nèi)核態(tài)可以訪問系統(tǒng)資源,比如:

處理器cpu:cpu控制著一個程序的執(zhí)行。輸入輸出IO:linux有句話叫“一切都是流”,也就是所有輸入輸出設(shè)備的數(shù)據(jù),包括硬盤,內(nèi)存,終端都可以像流一樣操作。進程管理:類似對進程的創(chuàng)建,休眠,喚醒,釋放之類的調(diào)度。比如linux下的fork和windows下的CreateProcess()函數(shù)。內(nèi)存:包括內(nèi)存的申請,釋放等管理操作。設(shè)備:這個就是常常說的外設(shè)了,比如鼠標,鍵盤。計時器:計算機能計時是因為晶體振蕩器產(chǎn)生的電磁脈沖。那么所有的定時任務(wù)都是以它為基礎(chǔ)的。進程間通信IPC:進程之間是不能夠互相訪問內(nèi)存的,所以進程與進程之間的交互需要通信,而通信也是一種資源。網(wǎng)絡(luò)通信網(wǎng)絡(luò)通信可以看做是進程見通信的特殊形式。

注釋:fflush把進程緩沖區(qū)的數(shù)據(jù)刷新到內(nèi)核緩沖區(qū),fsync把內(nèi)核緩沖區(qū)的數(shù)據(jù)刷新到物理媒介上。

而上面所說的這些系統(tǒng)資源,在用戶進程中是無法被直接訪問的,只能通過操作系統(tǒng)來訪問,所以也把操作系統(tǒng)提供的這些功能成為:“系統(tǒng)調(diào)用”。

比如下圖,展示一個用戶通過shell控制計算機所經(jīng)過的數(shù)據(jù)流向:文件讀寫和終端控制,都是通過內(nèi)核進行的。

圖片

提供這些限制的基礎(chǔ)就是cpu提供的內(nèi)核態(tài)和用戶態(tài)。比如intel x86 CPU有四種不同的執(zhí)行級別0-3,linux只使用了其中的0級和3級分別來表示內(nèi)核態(tài)和用戶態(tài)。

在用戶態(tài),不僅僅是系統(tǒng)資源了,就是別的進程的內(nèi)存對于你來說,都是“透明的”(并不是沒辦法訪問,否則游戲作弊器怎么實現(xiàn)?)

圖片

用戶進程緩存區(qū)

前面提到,用戶進程通過系統(tǒng)調(diào)用訪問系統(tǒng)資源的時候,需要切換到內(nèi)核態(tài),而這對應(yīng)一些特殊的堆棧和內(nèi)存環(huán)境,必須在系統(tǒng)調(diào)用前建立好。而在系統(tǒng)調(diào)用結(jié)束后,cpu會從核心模式切回到用戶模式,而堆棧又必須恢復(fù)成用戶進程的上下文。而這種切換就會有大量的耗時。

你看一些程序在讀取文件時,會先申請一塊內(nèi)存數(shù)組,稱為buffer,然后每次調(diào)用read,讀取設(shè)定字節(jié)長度的數(shù)據(jù),寫入buffer。(用較小的次數(shù)填滿buffer)。之后的程序都是從buffer中獲取數(shù)據(jù),當buffer使用完后,在進行下一次調(diào)用,填充buffer。所以說:用戶緩沖區(qū)的目的是為了減少系統(tǒng)調(diào)用次數(shù),從而降低操作系統(tǒng)在用戶態(tài)與核心態(tài)切換所耗費的時間。除了在進程中設(shè)計緩沖區(qū),內(nèi)核也有自己的緩沖區(qū)。

內(nèi)核緩存區(qū)

當一個用戶進程要從磁盤讀取數(shù)據(jù)時,內(nèi)核一般不直接讀磁盤,而是將內(nèi)核緩沖區(qū)中的數(shù)據(jù)復(fù)制到進程緩沖區(qū)中。

但若是內(nèi)核緩沖區(qū)中沒有數(shù)據(jù),內(nèi)核會把對數(shù)據(jù)塊的請求,加入到請求隊列,然后把進程掛起,為其它進程提供服務(wù)。

等到數(shù)據(jù)已經(jīng)讀取到內(nèi)核緩沖區(qū)時,把內(nèi)核緩沖區(qū)中的數(shù)據(jù)讀取到用戶進程中,才會通知進程,當然不同的io模型,在調(diào)度和使用內(nèi)核緩沖區(qū)的方式上有所不同,下一小結(jié)介紹。

你可以認為,read是把數(shù)據(jù)從內(nèi)核緩沖區(qū)復(fù)制到進程緩沖區(qū)。write是把進程緩沖區(qū)復(fù)制到內(nèi)核緩沖區(qū)。當然,write并不一定導(dǎo)致內(nèi)核的寫動作,比如os可能會把內(nèi)核緩沖區(qū)的數(shù)據(jù)積累到一定量后,再一次寫入。這也就是為什么斷電有時會導(dǎo)致數(shù)據(jù)丟失。所以說內(nèi)核緩沖區(qū),是為了在OS級別,提高磁盤IO效率,優(yōu)化磁盤寫操作。

流程

在《Unix網(wǎng)絡(luò)編程》中的五種io模型,也提到過進程緩沖區(qū)和內(nèi)核緩沖區(qū)。因為這個并不是此篇文章的重點,所以這里只對比阻塞模型和非阻塞。

圖片

圖片

對比阻塞和非阻塞,在阻塞io中,直到數(shù)據(jù)從內(nèi)核緩沖區(qū)拷貝到用戶緩沖區(qū)才通知用戶進程調(diào)用完成并喚醒,而非阻塞,在輪訓(xùn)得知數(shù)據(jù)準備好后,數(shù)據(jù)還是在內(nèi)核緩沖區(qū)中,等你去讀取,這也就是說數(shù)據(jù)準備好,并不代表已經(jīng)讀好可以使用。當然也不代表一定能讀。

緩存區(qū)和緩存

還有一部分人把緩沖區(qū)和緩存混淆,后來我明白這也是因為翻譯導(dǎo)致的把兩種東西進行混淆。緩沖區(qū)的英文是buffer,而緩存的應(yīng)為是cache。

圖片

CPU緩存(Cache Memory)是位于CPU與內(nèi)存之間的臨時存儲器,因為cpu的計算速度要比內(nèi)存的讀寫速度快很多,而把這些可能會被重復(fù)訪問到的數(shù)據(jù)存儲于cpu緩存中,就會提高讀取速度??梢哉f緩存是cpu和內(nèi)存之間的臨時存儲器。

也就是說,buffer是因為減少調(diào)用次數(shù),集中調(diào)用,提高系統(tǒng)性能。而cache是將讀取過的數(shù)據(jù)保存起來,重新讀取時若命中(找到需要的數(shù)據(jù))就不要去讀硬盤了,若沒有命中就讀硬盤。而緩沖可以理解為內(nèi)存和硬盤之間的臨時存儲器,重點是寫的過程。

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

    關(guān)注

    28

    文章

    3875

    瀏覽量

    139652
  • 緩沖
    +關(guān)注

    關(guān)注

    0

    文章

    53

    瀏覽量

    17893
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6941

    瀏覽量

    124155
  • 終端
    +關(guān)注

    關(guān)注

    1

    文章

    1169

    瀏覽量

    30199
收藏 人收藏

    評論

    相關(guān)推薦

    請問串口的DMA接收緩沖區(qū)是不是環(huán)形緩沖區(qū)

    系統(tǒng)在創(chuàng)建DMA緩沖區(qū)的時候,建立了put_index和get_index,會隨著數(shù)據(jù)的寫入和讀取修改它們的值;3、以上兩個相互配合,客觀上將DMA的緩沖區(qū)維護成了一個環(huán)形緩沖區(qū)不知
    發(fā)表于 08-30 14:27

    基于狀態(tài)圖的緩沖區(qū)溢出攻擊分析

    結(jié)合緩沖區(qū)溢出攻擊產(chǎn)生的原理,分析緩沖區(qū)溢出攻擊代碼的結(jié)構(gòu),論述Snort規(guī)則對緩沖區(qū)溢出攻擊的檢測,在此基礎(chǔ)上構(gòu)建一個基于狀態(tài)圖的緩沖區(qū)溢出攻擊的分析模型。該模型對
    發(fā)表于 04-10 08:46 ?32次下載

    環(huán)形緩沖區(qū)讀寫操作的分析與實現(xiàn)

    環(huán)形緩沖區(qū)是嵌入式系統(tǒng)中一種重要的常用數(shù)據(jù)結(jié)構(gòu)。在多任務(wù)環(huán)境下實現(xiàn)時,如果有多個讀寫任務(wù),一般需要用信號量來保護多個任務(wù)共享的環(huán)形緩沖區(qū)。但是如果只存在1 個讀
    發(fā)表于 04-15 11:35 ?40次下載

    清除鍵盤緩沖區(qū)原理

    清除鍵盤緩沖區(qū)原理 有時用戶的按鍵響應(yīng)可能導(dǎo)致數(shù)據(jù)丟失或破壞了數(shù)據(jù)而不能挽回。在這種情況下,消除緩
    發(fā)表于 06-12 23:07 ?2137次閱讀

    環(huán)形緩沖區(qū)的實現(xiàn)原理

    在通信程序中,經(jīng)常使用環(huán)形緩沖區(qū)作為數(shù)據(jù)結(jié)構(gòu)來存放通信中發(fā)送和接收的數(shù)據(jù)。環(huán)形緩沖區(qū)是一個先進先出的循環(huán)緩沖區(qū),可以向通信程序提供對緩沖區(qū)的互斥訪問。
    的頭像 發(fā)表于 03-22 10:03 ?7655次閱讀
    環(huán)形<b class='flag-5'>緩沖區(qū)</b>的實現(xiàn)原理

    緩沖區(qū)是啥意思 STM32串口數(shù)據(jù)接收之環(huán)形緩沖區(qū)

    緩沖區(qū)顧名思義是緩沖數(shù)據(jù)用的。實現(xiàn)緩沖區(qū)最簡單的辦法時,定義多個數(shù)組,接收一包數(shù)據(jù)到數(shù)組A,就把接收數(shù)據(jù)的地址換成數(shù)組B,每個數(shù)據(jù)有個標記字節(jié)用于表示這個數(shù)組是否收到數(shù)據(jù),收到數(shù)據(jù)是否處理
    的頭像 發(fā)表于 07-22 15:33 ?1.1w次閱讀

    STM32串口數(shù)據(jù)接收 --環(huán)形緩沖區(qū)

    STM32串口數(shù)據(jù)接收 --環(huán)形緩沖區(qū)環(huán)形緩沖區(qū)簡介??在單片機中串口通信是我們使用最頻繁的,使用串口通信就會用到串口的數(shù)據(jù)接收與發(fā)送,環(huán)形緩沖區(qū)方式接收數(shù)據(jù)可以更好的保證數(shù)據(jù)丟幀率第。??在通信
    發(fā)表于 12-28 19:24 ?31次下載
    STM32串口數(shù)據(jù)接收 --環(huán)形<b class='flag-5'>緩沖區(qū)</b>

    什么是緩沖區(qū)?有什么作用

    緩沖區(qū)其實就是一個存儲區(qū)域,它是由專門的硬件寄存器所組成的。
    的頭像 發(fā)表于 02-02 09:57 ?2.6w次閱讀

    消除IoT上的緩沖區(qū)溢出漏洞

    黑客可以使用堆棧緩沖區(qū)溢出將可執(zhí)行文件替換為惡意代碼,從而允許他們利用堆內(nèi)存或調(diào)用堆棧本身等系統(tǒng)資源。例如,控制流劫持利用堆棧緩沖區(qū)溢出將代碼執(zhí)行重定向到正常操作中使用的位置以外的位置
    的頭像 發(fā)表于 10-12 15:25 ?1011次閱讀
    消除IoT上的<b class='flag-5'>緩沖區(qū)</b>溢出漏洞

    消除物聯(lián)網(wǎng)上的緩沖區(qū)溢出漏洞

      黑客可以使用堆棧緩沖區(qū)溢出將可執(zhí)行文件替換為惡意代碼,從而使他們能夠利用堆內(nèi)存或調(diào)用堆棧本身等系統(tǒng)資源。例如,控制流劫持利用堆棧緩沖區(qū)溢出將代碼執(zhí)行重定向到正常操作中使用的位置以外
    的頭像 發(fā)表于 12-02 11:57 ?1088次閱讀

    環(huán)形緩沖區(qū)的實現(xiàn)思路

    單片機程序開發(fā)一般都會用到UART串口通信,通過通信來實現(xiàn)上位機和單片機程序的數(shù)據(jù)交互。通信中為了實現(xiàn)正常的收發(fā),一般都會有對應(yīng)的發(fā)送和接收緩存來暫存通信數(shù)據(jù)。這里使用環(huán)形緩沖區(qū)的方式來設(shè)計數(shù)據(jù)收發(fā)的緩存,即緩沖區(qū)溢出后,從緩沖區(qū)
    的頭像 發(fā)表于 01-17 15:07 ?1761次閱讀

    C++環(huán)形緩沖區(qū)設(shè)計與實現(xiàn)

    一、環(huán)形緩沖區(qū)基礎(chǔ)理論解析(Basic Theory of Circular Buffer) 1.1 環(huán)形緩沖區(qū)的定義與作用(Definition and Function of Circular
    的頭像 發(fā)表于 11-09 11:21 ?2438次閱讀
    C++環(huán)形<b class='flag-5'>緩沖區(qū)</b>設(shè)計與實現(xiàn)

    西門子博診斷緩沖區(qū)的使用方法

    可從在線和診斷視圖中“診斷”文件夾的“診斷緩沖區(qū)”組中讀出 CPU 的診斷緩沖區(qū)。
    的頭像 發(fā)表于 12-11 10:24 ?4866次閱讀
    西門子博診斷<b class='flag-5'>緩沖區(qū)</b>的使用方法

    交換芯片緩沖區(qū)大小是什么

    交換芯片緩沖區(qū)大小并不一定是固定的。緩沖區(qū)的設(shè)計和實現(xiàn)會根據(jù)芯片的具體型號、規(guī)格以及應(yīng)用場景的不同而有所差異。一些交換芯片可能具有固定大小的緩沖區(qū),以滿足特定的性能需求或成本限制。然而,隨著技術(shù)
    的頭像 發(fā)表于 03-18 14:42 ?742次閱讀

    RTOS的流緩沖區(qū)機制解析

    SAFERTOS中的流緩沖區(qū)(Stream buffer)機制,可以實現(xiàn)任務(wù)到任務(wù)或中斷到任務(wù)之間的通信。字節(jié)流是由發(fā)送方寫入緩沖區(qū),接收方讀取緩沖區(qū)數(shù)據(jù)。流緩沖區(qū)作為隊列的輕量級級替
    的頭像 發(fā)表于 02-14 11:33 ?139次閱讀
    RTOS的流<b class='flag-5'>緩沖區(qū)</b>機制解析
    主站蜘蛛池模板: 最近中文字幕mv手机免费高清 | 在线日韩欧美一区二区三区 | 久青草国产在视频在线观看 | YELLOW视频直播在线观看高清 | 久久偷拍vs国产在线播放 | www.精品久久| 精品久久久久中文字幕 | 亚洲 日本 欧美 中文字幕 | 亚洲国产精品无码AV久久久 | 久久久中日AB精品综合 | 古代又黄又肉到湿的爽文 | 欧洲美女人 一级毛片 | 暖暖视频中国在线观看免费韩国 | 国产乱色伦影片在线观看 | 99精品免费久久久久久久久蜜桃 | 9久高清在线不卡免费无吗视频 | 日本夜爽爽一区二区三区 | 伊人电院网| 国产午夜AV无码无片久久96 | 把英语老师强奷到舒服动态图 | 午夜伦伦电影理论片费看 | 国产亚洲精品久久77777 | 午夜伦理电影在线观免费 | 久久国语精品 | 思思99精品国产自在现线 | 香蕉动漫库 | 小柔的性放荡羞辱日记动漫 | 国产午夜视频在线 | 一二三区乱码不卡手机版 | 男人J桶进男人屁股过程 | 一个人免费观看在线视频播放 | 国产毛多水多高潮高清 | 龙岩综合频道 | 99精品免费观看 | 亚洲国产精品无码AV久久久 | 亚洲中文字幕AV在天堂 | 一本道无码字幕在线看 | 毛片手机在线看 | 一一本之道高清视频在线观看中文字幕 | 日本无码欧美激情在线视频 | 久久免费视频在线观看6 |