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

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

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

五種IO模型盤點(diǎn)

h1654155282.3538 ? 來源:陳翠 ? 2019-09-13 12:54 ? 次閱讀

阻塞IO

假如A在河邊釣魚的時(shí)候,非常的專心,生怕魚兒溜掉,故此,A就一直盯著魚竿,一直等著魚兒上鉤,專心的做這一件事情,直到魚兒上鉤,才結(jié)束這個(gè)動(dòng)作,這就是阻塞IO。在內(nèi)核把數(shù)據(jù)準(zhǔn)備好之前,系統(tǒng)調(diào)用會(huì)一直處于阻塞狀態(tài)。

非阻塞IO

假如B也在河邊釣魚,B不想像A一樣把所有的時(shí)間都花在等魚兒上鉤這件事情上,所以他的做法就是在等待魚兒上鉤的同時(shí),自己也可以看看書,刷刷小編的博客,聊天等等。但是B也不是就不管魚兒了,他會(huì)每隔一段固定時(shí)間都來看一下,有沒有魚兒上鉤,如果有魚兒上鉤,他就結(jié)束這個(gè)動(dòng)作,這就是非阻塞IO。

非阻塞IO往往需要程序員循環(huán)的方式反復(fù)嘗試讀取文件描述符,這個(gè)過程稱為輪詢,這對(duì)于cpu來說的話是較大的浪費(fèi),一般只有特定的場(chǎng)景下才能使用。

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

假如C也在河邊釣魚,他認(rèn)為A、B不夠聰明,故此,他想了一種辦法,就是在魚竿上掛上了一個(gè)鈴鐺,當(dāng)有魚兒上鉤的時(shí)候,鈴鐺就會(huì)被觸發(fā),發(fā)出響聲,他就可以過去將魚兒釣上來了。信號(hào)驅(qū)動(dòng)IO模型,應(yīng)用進(jìn)程告訴內(nèi)核:當(dāng)數(shù)據(jù)報(bào)準(zhǔn)備好的時(shí)候,給我發(fā)送一個(gè)信號(hào),對(duì)SIGIO信號(hào)進(jìn)行捕捉,并且調(diào)用我的信號(hào)處理函數(shù)來獲取數(shù)據(jù)報(bào)。

IO多路轉(zhuǎn)接

假如D也在河邊釣魚,但是D是一個(gè)土豪,他一個(gè)人就拿了好多魚竿擺在哪里,這樣很明顯就增加了魚兒上鉤的機(jī)會(huì)。他只需要不斷地查看每個(gè)魚竿是否有魚兒上鉤就行了,提高了效率。實(shí)際上最核心在于IO多路轉(zhuǎn)接能夠同時(shí)等待多個(gè)文件描述符的就緒狀態(tài)。

異步IO

假如E也想釣魚,但是他又有點(diǎn)忙,所以他雇傭了一個(gè)人專門幫他看著魚竿,一旦有魚兒上鉤,就讓這個(gè)人通知他,他過來將魚兒釣上來。由內(nèi)核在數(shù)據(jù)拷貝完成時(shí),通知應(yīng)用程序(信號(hào)驅(qū)動(dòng)是告訴應(yīng)用程序何時(shí)可以開始拷貝數(shù)據(jù))。

任何IO過程中,都包含兩個(gè)步驟。第一是等待,第二是拷貝。而且在實(shí)際的應(yīng)用場(chǎng)景中,等待消耗的時(shí)間往往都遠(yuǎn)遠(yuǎn)高于拷貝的時(shí)間。讓IO更高效,最核心的辦法就是讓等待的時(shí)間盡量少。

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

    關(guān)注

    3

    文章

    1376

    瀏覽量

    40316
  • 應(yīng)用程序
    +關(guān)注

    關(guān)注

    37

    文章

    3283

    瀏覽量

    57747
收藏 人收藏

    評(píng)論

    相關(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 ?838次閱讀

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

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

    淺析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

    IO模型分別有哪幾種?它們有什么異同?

    IO模型分別有哪幾種?這幾種IO模型的有什么相同點(diǎn) ?這幾種IO模型的有什么不同點(diǎn)?
    發(fā)表于 06-21 07:10

    【微科技CF3310開發(fā)板試用體驗(yàn)】之安全算法小盤點(diǎn)

    科技CF3310開發(fā)板有一個(gè)很大特點(diǎn)就是安全算法的無縫嵌入,這也是吸引我很大興趣的一個(gè)地方,今天就一起來盤點(diǎn),共同增益知識(shí)及使用方式。目前官方DEMO里整合了6算法:SM4,DES,AES
    發(fā)表于 07-02 15:39

    盤點(diǎn)6常規(guī)AMOLED技術(shù)

    盤點(diǎn)6常規(guī)AMOLED技術(shù)
    發(fā)表于 01-24 16:15 ?25次下載

    一文詳細(xì)了解IO模型

    IO模型包括:阻塞IO、非阻塞IO、IO多路復(fù)用
    的頭像 發(fā)表于 02-14 14:38 ?5922次閱讀
    一文詳細(xì)了解<b class='flag-5'>五</b><b class='flag-5'>種</b><b class='flag-5'>IO</b><b class='flag-5'>模型</b>

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

    阻塞 IO 模型 在Linux ,默認(rèn)情況下所有的 socket 都是阻塞的,一個(gè)典型的讀操作流程如圖所示。 阻塞和非阻塞的概念描述的是用戶線程調(diào)用內(nèi)核 IO 操作的方式:阻塞是指 IO
    的頭像 發(fā)表于 10-08 17:16 ?869次閱讀
    網(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 ?797次閱讀
    多路<b class='flag-5'>IO</b>復(fù)用<b class='flag-5'>模型</b>和異步<b class='flag-5'>IO</b><b class='flag-5'>模型</b>介紹

    斷路器跳閘常見的原因盤點(diǎn)

    斷路器跳閘,無外乎以下原因:過載、短路、漏電、欠壓和過壓。下面我們來詳細(xì)了解一下這五種原因以及如何判斷和解決故障。
    的頭像 發(fā)表于 10-17 16:05 ?1.1w次閱讀

    什么是波特模型,如何應(yīng)用

    波特模型(Porter's Five Forces Model)是邁克爾·波特(Michael E. Porter)于1979年提出的,用于分析行業(yè)競(jìng)爭狀況和企業(yè)競(jìng)爭戰(zhàn)略的一理論模型
    的頭像 發(fā)表于 07-05 14:36 ?2469次閱讀

    一文解讀Linux 5IO模型

    Linux里有IO模型:阻塞IO、非阻塞IO、多路復(fù)用I
    的頭像 發(fā)表于 11-09 11:12 ?343次閱讀
    一文解讀Linux 5<b class='flag-5'>種</b><b class='flag-5'>IO</b><b class='flag-5'>模型</b>