在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

一文解讀Linux 5種IO模型

Linux愛好者 ? 來源:Linux愛好者 ? 2024-11-09 11:12 ? 次閱讀

Linux里有五種IO模型:阻塞IO、非阻塞IO、多路復(fù)用IO、信號(hào)驅(qū)動(dòng)式IO和異步IO,我發(fā)現(xiàn)這五種IO模型,其實(shí)能和吃飯這件事關(guān)聯(lián)起來。

阻塞IO(Blocking I/O)

阻塞IO是最常見的IO模型。

當(dāng)發(fā)起一個(gè)IO操作時(shí),比如讀取數(shù)據(jù),系統(tǒng)會(huì)調(diào)用read()函數(shù)。如果請求的數(shù)據(jù)沒有準(zhǔn)備好,此時(shí)進(jìn)程會(huì)被掛起(blocked),進(jìn)入等待狀態(tài)。直到數(shù)據(jù)準(zhǔn)備好,而且復(fù)制到應(yīng)用進(jìn)程的緩沖區(qū),這時(shí)候才會(huì)返回。

從調(diào)用到返回,整個(gè)時(shí)間段都是阻塞的,所以被稱為阻塞IO。

17f10f3e-9041-11ef-a511-92fbcf53809c.png

阻塞IO

就像是手機(jī)沒電的時(shí)候,去飯館吃飯,我點(diǎn)完菜,只能等著廚師做好,服務(wù)員端上來,我才能愉快干飯。這段時(shí)間,我就只能坐在座位上干等。

非阻塞IO(Non-Blocking I/O)

阻塞IO,還是比較浪費(fèi)資源的,那么非阻塞IO就來了。

所謂非阻塞IO,是在調(diào)用IO操作時(shí),如果緩沖區(qū)沒有數(shù)據(jù)的話,直接返回一個(gè)錯(cuò)誤碼。應(yīng)用進(jìn)程需要不斷輪詢,來檢查數(shù)據(jù)是否準(zhǔn)備好。數(shù)據(jù)準(zhǔn)備好了,就返回?cái)?shù)據(jù)。

180c28be-9041-11ef-a511-92fbcf53809c.png

非阻塞IO

就像是我奢侈一把,想吃個(gè)西餐,于是就去了肯德基,點(diǎn)完餐,我就可以坐著刷刷手機(jī)。當(dāng)然,我還需要時(shí)不時(shí)地看看我的餐是不是已經(jīng)備好,餐備好了,就去取一下。

多路復(fù)用IO(I/O Multiplexing)

雖然非阻塞IO相比阻塞IO,性能提升了很多,但是輪詢過程中,還是有大量的系統(tǒng)調(diào)用,上下文切換的開銷比較大。

那么,多路復(fù)用IO就來了。

多路指的是多個(gè)數(shù)據(jù)通道,復(fù)用指的是一個(gè)進(jìn)程可以同時(shí)監(jiān)控多個(gè)文件描述符(比如socket),當(dāng)某個(gè)文件描述符狀態(tài)發(fā)生變化(比如變得可讀或可寫),多路復(fù)用的函數(shù)將返回變化的文件描述符。

這樣,在數(shù)據(jù)傳輸過程中,同一個(gè)進(jìn)程中不同的任務(wù)都能被處理。特點(diǎn)是在數(shù)據(jù)傳輸過程中,進(jìn)程能夠同時(shí)處理多個(gè)任務(wù),提高了程序的效率。

select、poll、epoll 等都是 I/O 多路復(fù)用的具體實(shí)現(xiàn)。

以select/poll為例,進(jìn)程通過將一個(gè)或多個(gè)fd傳遞給select或poll系統(tǒng)調(diào)用,阻塞在select操作上,這樣select/poll可以偵測多個(gè)fd是否處于就緒狀態(tài)。當(dāng)有fd就緒時(shí),立即回調(diào)函數(shù)rollback,接下來就可以進(jìn)行讀取。

1821e5a0-9041-11ef-a511-92fbcf53809c.png

多路復(fù)用IO

就像是我想吃頓好的,于是選擇去吃自助餐,自助餐有很多餐區(qū),我先看看哪個(gè)餐區(qū)有我想吃的菜,然后端著盤子去取就行了,一個(gè)人就可以取多個(gè)菜,肉、蔬菜、水果,什么都能吃一點(diǎn),而且不用怎么等。

信號(hào)驅(qū)動(dòng)式IO(Signal-Driven I/O)

信號(hào)驅(qū)動(dòng)式IO利用信號(hào)機(jī)制來進(jìn)行數(shù)據(jù)傳輸。

進(jìn)程首先告訴內(nèi)核,當(dāng)數(shù)據(jù)準(zhǔn)備好時(shí),請發(fā)送一個(gè)SIGIO信號(hào)。進(jìn)程繼續(xù)執(zhí)行其他任務(wù),等到收到信號(hào)后,再開始進(jìn)行數(shù)據(jù)傳輸。

183a8d76-9041-11ef-a511-92fbcf53809c.png

信號(hào)驅(qū)動(dòng)IO

就像是我去吃飯,外帶,跟服務(wù)員打聲招呼,餐好了通知我,這時(shí)候我就可以去干其它事情,餐備好之后,服務(wù)員通知我,我取餐就行了。

異步IO(Asynchronous I/O)

異步IO是指當(dāng)發(fā)起一個(gè)IO操作后,系統(tǒng)會(huì)立即返回。異步IO操作在后臺(tái)進(jìn)行數(shù)據(jù)傳輸,數(shù)據(jù)傳輸完成后,系統(tǒng)將通知進(jìn)程。這樣,在整個(gè)數(shù)據(jù)傳輸?shù)倪^程中,進(jìn)程都可以執(zhí)行其他任務(wù),不需要等待。

1853a55e-9041-11ef-a511-92fbcf53809c.png

異步IO

就像是準(zhǔn)備吃飯了,我自己懶得動(dòng),直接在某團(tuán)上點(diǎn)個(gè)餐,點(diǎn)完之后愛干啥干啥,等著快遞小哥給我送到就行了。

可以看到,阻塞和非阻塞主要指的是等待數(shù)據(jù)這個(gè)過程應(yīng)用進(jìn)程需不需要掛起,同步和異步指的是等待數(shù)據(jù)和數(shù)據(jù)拷貝這兩個(gè)過程應(yīng)用進(jìn)程需不需要掛起,只有異步IO做到了完全異步。

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

    關(guān)注

    0

    文章

    448

    瀏覽量

    39152
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11304

    瀏覽量

    209497

原文標(biāo)題:一頓飯的事兒,搞懂 Linux 5 種 IO 模型

文章出處:【微信號(hào):LinuxHub,微信公眾號(hào):Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    Linux驅(qū)動(dòng)開發(fā)之IO模型介紹

    Linux驅(qū)動(dòng)開發(fā)中,應(yīng)用程序通過循環(huán)讀取或者中斷的方式都會(huì)使得CPU的占用率很高。本文介紹五IO模型,可以用來優(yōu)化文件讀寫方式,降低CPU的使用率。
    發(fā)表于 07-29 09:03 ?832次閱讀

    Linux驅(qū)動(dòng)學(xué)習(xí)筆記:異步IO

    前幾篇介紹了幾種IO模型,今天介紹另一種IO模型——異步IO
    發(fā)表于 06-12 16:24 ?694次閱讀

    Java NIO編程理論基礎(chǔ)之Java IOlinux網(wǎng)絡(luò)IO模型發(fā)展

    Java NIO編程理論基礎(chǔ)篇——Java IO的發(fā)展以及linux網(wǎng)絡(luò)IO模型
    發(fā)表于 07-18 12:40

    淺析java的IO模型

    java IO初識(shí)與Linux網(wǎng)絡(luò)IO模型簡介
    發(fā)表于 08-05 06:28

    linux下的IO模型詳解

      開門見山,Linux下的如中IO模型:阻塞IO模型,非阻塞IO
    發(fā)表于 10-09 16:12

    Linux鐵三角之IO()—— IO模型

    PPT分享: Linux鐵三角之IO()—— IO模型
    發(fā)表于 06-12 15:52

    Linux文件系統(tǒng)與IO流程和模型

    今晚9點(diǎn): 《Linux文件系統(tǒng)與IO流程和模型》微課(415-418)
    發(fā)表于 06-13 16:51

    解讀HEVC視頻標(biāo)準(zhǔn)的環(huán)內(nèi)濾波,看完你就懂了

    解讀HEVC視頻標(biāo)準(zhǔn)的環(huán)內(nèi)濾波,看完你就懂了
    發(fā)表于 06-03 06:08

    詳細(xì)了解五IO模型

    IO模型包括:阻塞IO、非阻塞IOIO多路復(fù)用、信號(hào)驅(qū)動(dòng)
    的頭像 發(fā)表于 02-14 14:38 ?5905次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>詳細(xì)了解五<b class='flag-5'>種</b><b class='flag-5'>IO</b><b class='flag-5'>模型</b>

    詳解linux的分頁模型

    linux下的邏輯地址=線性地址。也就是,我們編碼使用的是線性地址,之后只需要經(jīng)過個(gè)分頁機(jī)制就可以把這個(gè)地址轉(zhuǎn)為物理地址了。所以我們更重要的可能是去說明linux的分頁
    的頭像 發(fā)表于 05-18 08:59 ?2122次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>詳解<b class='flag-5'>linux</b>的分頁<b class='flag-5'>模型</b>

    Linux5IO模型

    通過 I/O 復(fù)用函數(shù)向內(nèi)核注冊組事件,內(nèi)核通過 I/O 復(fù)用函數(shù)把其中就緒的事件通知給應(yīng)用程序。
    的頭像 發(fā)表于 08-12 09:22 ?1034次閱讀

    網(wǎng)絡(luò)IO模型:阻塞與非阻塞

    阻塞 IO 模型Linux ,默認(rèn)情況下所有的 socket 都是阻塞的,個(gè)典型的讀操作流程如圖所示。 阻塞和非阻塞的概念描述的是用戶線程調(diào)用內(nèi)核
    的頭像 發(fā)表于 10-08 17:16 ?856次閱讀
    網(wǎng)絡(luò)<b class='flag-5'>IO</b><b class='flag-5'>模型</b>:阻塞與非阻塞

    多路IO復(fù)用模型和異步IO模型介紹

    多路 IO 復(fù)用模型 多路 IO 復(fù)用,有時(shí)也稱為事件驅(qū)動(dòng) IO。它的基本原理就是有個(gè)函數(shù)會(huì)不斷地輪詢所負(fù)責(zé)的所有 socket ,當(dāng)某個(gè) socket有數(shù)據(jù)到達(dá)了,就通知用戶進(jìn)程。
    的頭像 發(fā)表于 10-08 17:21 ?790次閱讀
    多路<b class='flag-5'>IO</b>復(fù)用<b class='flag-5'>模型</b>和異步<b class='flag-5'>IO</b><b class='flag-5'>模型</b>介紹

    linux異步io框架iouring應(yīng)用

    Linux內(nèi)核5.1支持了新的異步IO框架iouring,由Block IO大神也即Fio作者Jens Axboe開發(fā),意在提供套公用的網(wǎng)絡(luò)和磁盤異步
    的頭像 發(fā)表于 11-08 15:39 ?678次閱讀
    <b class='flag-5'>linux</b>異步<b class='flag-5'>io</b>框架iouring應(yīng)用

    解讀GNSS信號(hào)對網(wǎng)絡(luò)中授時(shí)應(yīng)用的益處

    漲知識(shí) | 解讀GNSS信號(hào)對網(wǎng)絡(luò)中授時(shí)應(yīng)用的益處
    的頭像 發(fā)表于 11-24 14:26 ?519次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>解讀</b>GNSS信號(hào)對網(wǎng)絡(luò)中授時(shí)應(yīng)用的益處
    主站蜘蛛池模板: 天天操天天谢| vvvv98国产成人综合青青| 高清毛片aaaaaaaaa片| 天天视频色| 手机成人在线视频| 91大神在线视频观看| 特级毛片女人18毛片| 日韩三级久久| 夜夜草天天干| 3344在线观看永久免费| 成人a网| 五月婷婷基地| 热久久综合这里只有精品电影| 久久综合九色综合欧美狠狠| 成人网18免费下| 人人干人人干| 成人欧美一区二区三区白人| 99精品热| 激情综合在线观看| 天天射天天操天天干| 亚洲色图27p| 欧美日韩国产一区二区 | 人人人草| 中文在线最新版天堂bt| 国产一卡二卡3卡4卡四卡在线 | 四虎永久精品免费网址大全| 99免费视频观看| 国产伦精品一区二区三区女| 亚洲国产精品va在线观看麻豆| 萌白酱一线天粉嫩喷水在线观看| 在线色资源| а8天堂资源在线官网| 国内视频一区二区三区| 欧美性色欧美a在线观看| 新午夜影院| 久久99热久久精品动漫| 免费一级特黄特色大片在线| 天天操天天操天天操| 一色屋成人免费精品网| 久久久久久久网站| 日本69xxxx|