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

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

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

POSIX對同步、異步I/O的定義

Linux愛好者 ? 來源:lq ? 2019-04-27 18:19 ? 次閱讀

一. POSIX對同步、異步I/O的定義

我們先大致看看POSIX對同步、異步的定義,不用細(xì)究,重點看我標(biāo)紅的部分就行。

同步I/O會導(dǎo)致請求進程阻塞,直到I/O操作完成;

異步I/O不會導(dǎo)致請求進程阻塞。

二. 同步、異步,阻塞、非阻塞

個人理解同步與否與阻塞與否只是看待問題的不同維度,不用過于追究同步和阻塞有什么區(qū)別、以及異步和非阻塞有什么區(qū)別。

我用小明購買火車票的例子大致先講述下同步、異步,阻塞、非阻塞這幾種情況的組合。

同步阻塞,小明去火車站買票。首先,他需要在某一個售票窗口排隊,當(dāng)輪到他買票時,他需要告訴售票員他需要一張去上海的火車票,然后售票員需要去系統(tǒng)查詢是否還有余票,有的話再收款出票,最后再把票給小明。在火車票到手之前,小明都不能做其他的事情,這種情況我們可以理解為阻塞。

同步非阻塞,小明委托黃牛幫忙買火車票,然后小明可以做其他事情,但是需要每隔10分鐘就打電話去詢問黃牛票是否買到。黃牛買到票后,打電話通知小明說票已經(jīng)買到,小明再去黃牛那里取火車票。這里的非阻塞指的是黃牛在買票的過程中,小明是不用等待的,他可以做其他事情,只是需不時地去詢問黃牛票是否買好。但是,在小明去黃牛那里取票的過程中,小明還是不能做其他事情。

異步阻塞,基本上沒有這個說法。

異步非阻塞,小明委托黃牛幫忙買火車票,然后小明可以做其他事情,黃牛買好票后會自動把票送到小明的家里。在這整個過程中,小明都可以做他自己想做的事情,不會被阻塞。

三. Unix中的I/O模型

OK,有了上面的基礎(chǔ)過后,我們可以開始講I/O模型了。

網(wǎng)絡(luò)Socket的輸入操作中,I/O大致可以分為兩個階段,這個兩個階段大家務(wù)必掌握:

數(shù)據(jù)從網(wǎng)絡(luò)中抵達,然后數(shù)據(jù)被復(fù)制到系統(tǒng)內(nèi)核的緩沖區(qū);

系統(tǒng)內(nèi)核將內(nèi)核緩沖區(qū)中的數(shù)據(jù)復(fù)制到用戶進程的緩沖區(qū)中。

在Unix中有5種I/O模型,它們是:

阻塞式I/O

非阻塞式I/O

多路復(fù)用I/O

信號驅(qū)動I/O

異步I/O

下面,我們逐一分析每種I/O模型。

1.阻塞式I/O

阻塞式I/O,即Blocking I/O。用戶發(fā)起一個recvfrom系統(tǒng)調(diào)用,內(nèi)核會等待數(shù)據(jù)從網(wǎng)絡(luò)中到達。一旦數(shù)據(jù)準(zhǔn)備就緒,系統(tǒng)內(nèi)核將把自己的緩沖區(qū)中的數(shù)據(jù)拷貝到用戶進程的緩沖區(qū)。在系統(tǒng)內(nèi)核等待數(shù)據(jù)、復(fù)制數(shù)據(jù)的過程中,用戶進程是不能做其他任何事情的,只能等待內(nèi)核完成上述一系列的操作。

2.非阻塞式I/O

與阻塞式I/O不同,非阻塞式I/O中,用戶進程在發(fā)起recvfrom系統(tǒng)調(diào)用后可以立即返回,但是用戶進程需要不時地循環(huán)詢問系統(tǒng)內(nèi)核數(shù)據(jù)是否已經(jīng)準(zhǔn)備就緒,即輪詢(polling)。輪詢往往會消耗大量的CPU時間。

下圖中,用戶進程發(fā)起recvfrom系統(tǒng)調(diào)用,由于系統(tǒng)內(nèi)核中數(shù)據(jù)尚未就緒,內(nèi)核會立即返回EWOULDBLOCK錯誤碼,防止用戶進程阻塞。如此往復(fù),直到系統(tǒng)內(nèi)核中數(shù)據(jù)準(zhǔn)備就緒。在數(shù)據(jù)就緒前,用戶進程是非阻塞的,這也就是為什么這種模型叫非阻塞式I/O的原因。數(shù)據(jù)就緒后,和阻塞式I/O一樣,內(nèi)核將數(shù)據(jù)拷貝至用戶進程,在數(shù)據(jù)拷貝的過程中,用戶進程是阻塞的。

3.多路復(fù)用I/O

多路復(fù)用I/O的關(guān)鍵函數(shù)為select或者poll。我們以select函數(shù)為例,當(dāng)我們調(diào)用該函數(shù)時,用戶進程將阻塞,直到系統(tǒng)內(nèi)核中的數(shù)據(jù)準(zhǔn)備好。數(shù)據(jù)就緒后,系統(tǒng)會通知用戶進程數(shù)據(jù)已經(jīng)可讀,然后用戶進程會發(fā)起recvfrom系統(tǒng)調(diào)用,將數(shù)據(jù)從內(nèi)核拷貝到用戶進程,在數(shù)據(jù)拷貝期間,用戶進程是阻塞的。

使用多路復(fù)用的優(yōu)勢是我們可以等待多個描述符就緒,對應(yīng)到Java NIO多路復(fù)用模型中就是我們可以使用一個線程監(jiān)聽多個Channel的請求。

4.信號驅(qū)動I/O

信號驅(qū)動I/O模型主要是讓內(nèi)核在描述符就緒的時候發(fā)送SIGIO信號通知用戶進程,據(jù)我的了解,這種I/O模式運用的并不多,這里就不多描述,直接看圖吧。

5.異步I/O

用戶進程在調(diào)用異步I/O函數(shù)后會立即返回,并且會讓內(nèi)核在完成所有操作后通知用戶進程。在內(nèi)核進行I/O操作的期間,我們的用戶進程不會阻塞。特別需要注意的是,和前面四中I/O模型不同,異步I/O模型在內(nèi)核將數(shù)據(jù)拷貝到用戶進程時,我們的用戶進程不會阻塞。

四. I/O模型對比

對比上述5中I/O模型我們可以發(fā)現(xiàn),前面4種模型的區(qū)別主要在第一階段,而第二階段都是一樣的,即將數(shù)據(jù)從內(nèi)核拷貝到用戶進程時都會阻塞。根據(jù)POSIX對同步、異步I/O的定義,可以得出前4種模型都屬于同步I/O。而第5種I/O,即異步I/O,兩個階段的操作都是由系統(tǒng)內(nèi)核來處理的,用戶進程并沒有介入。

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

    關(guān)注

    14

    文章

    7485

    瀏覽量

    88541
  • UNIX
    +關(guān)注

    關(guān)注

    0

    文章

    296

    瀏覽量

    41393
  • Posix
    +關(guān)注

    關(guān)注

    0

    文章

    36

    瀏覽量

    9480

原文標(biāo)題:Unix 中的 I/O 模型

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

收藏 人收藏

    評論

    相關(guān)推薦

    i.MX6ULL】驅(qū)動開發(fā)9——Linux I/O模型分析并進來類比

    本篇介紹了Linux中的五種I/O模型:阻塞式I/O模型、非阻塞式I/O模型、
    的頭像 發(fā)表于 05-26 09:05 ?2221次閱讀
    【<b class='flag-5'>i</b>.MX6ULL】驅(qū)動開發(fā)9——Linux <b class='flag-5'>I</b>/<b class='flag-5'>O</b>模型分析并進來類比

    Xilinx FPGA異步復(fù)位同步釋放—同步后的復(fù)位該當(dāng)作同步復(fù)位還是異步復(fù)位?

    針對異步復(fù)位、同步釋放,一直沒搞明白在使用同步化以后的復(fù)位信號時,到底是使用同步復(fù)位還是異步復(fù)位?
    發(fā)表于 06-21 09:59 ?1347次閱讀
    Xilinx FPGA<b class='flag-5'>異步</b>復(fù)位<b class='flag-5'>同步</b>釋放—<b class='flag-5'>同步</b>后的復(fù)位該當(dāng)作<b class='flag-5'>同步</b>復(fù)位還是<b class='flag-5'>異步</b>復(fù)位?

    Linux設(shè)備驅(qū)動中的異步通知與異步I/O

    ;信號驅(qū)動的異步I/O"。Linux信號Linux系統(tǒng)中,異步通知使用信號來實現(xiàn)。信號也就是一種軟件中斷。信號的產(chǎn)生:kill raise alarm用戶按下某些終端鍵;硬件異常;終止
    發(fā)表于 02-21 10:52

    測試serialX的posix支持詳解

    Interface) layer” 子菜單項,選擇“Enable POSIX file system and I/O”“Enable I/O
    發(fā)表于 02-14 11:29

    冗余I/O

    6.1 冗余I/O定義當(dāng)I/O模塊以每兩個一組組態(tài)成冗余對運行時,I/
    發(fā)表于 07-23 00:29 ?26次下載

    Java I/O 的相關(guān)方法分析

    (select and poll),signal driven I/O (SIGIO),asynchronous I/O (the POSIX
    發(fā)表于 09-27 13:18 ?0次下載
    Java <b class='flag-5'>I</b>/<b class='flag-5'>O</b> 的相關(guān)方法分析

    posix是什么

    POSIX表示可移植操作系統(tǒng)接口,POSIX標(biāo)準(zhǔn)定義了操作系統(tǒng)應(yīng)該為應(yīng)用程序提供的接口標(biāo)準(zhǔn),是IEEE為要在各種UNIX操作系統(tǒng)上運行的軟件而定義的一系列API標(biāo)準(zhǔn)的總稱,其正式稱呼為
    發(fā)表于 11-14 15:09 ?1.1w次閱讀
    <b class='flag-5'>posix</b>是什么

    異步傳輸和同步傳輸?shù)膮^(qū)別介紹

    本文開始對異步傳輸進行了介紹,其中包括了異步傳輸工作原理和異步傳輸模式,其次介紹了同步傳輸?shù)?b class='flag-5'>定義和特點,最后詳細(xì)介紹了
    發(fā)表于 03-02 14:09 ?1w次閱讀
    <b class='flag-5'>異步</b>傳輸和<b class='flag-5'>同步</b>傳輸?shù)膮^(qū)別介紹

    執(zhí)行和理解I/O特征分析

    Learn about tools available for understanding I/O patterns. Understand output in context
    的頭像 發(fā)表于 10-26 06:10 ?1694次閱讀

    同步復(fù)位和異步復(fù)位電路簡介

    同步復(fù)位和異步復(fù)位都是狀態(tài)機的常用復(fù)位機制,圖1中的復(fù)位電路結(jié)合了各自的優(yōu)點。同步復(fù)位具有時鐘和復(fù)位信號之間同步的優(yōu)點,這可以防止時鐘和復(fù)位信號之間發(fā)生競爭條件。但是,
    的頭像 發(fā)表于 08-12 15:20 ?7358次閱讀
    <b class='flag-5'>同步</b>復(fù)位和<b class='flag-5'>異步</b>復(fù)位電路簡介

    2022 RT-Thread全球技術(shù)大會:POSIX如何定義各種功能

    POSIX如何定義各種功能?有哪些標(biāo)準(zhǔn)?
    的頭像 發(fā)表于 05-27 16:42 ?771次閱讀
    2022 RT-Thread全球技術(shù)大會:<b class='flag-5'>POSIX</b>如何<b class='flag-5'>定義</b>各種功能

    異步電機與同步電機的區(qū)別是什么

    的優(yōu)缺點又有哪些來幫助大家更好地了解這兩種電機。 1、同步電機與異步電機的區(qū)別 ①電機的基本定義同步電機的轉(zhuǎn)速等于定子旋轉(zhuǎn)磁場的轉(zhuǎn)速。異步
    發(fā)表于 05-25 16:46 ?2327次閱讀

    XPHY I/O同步接口應(yīng)用說明

    電子發(fā)燒友網(wǎng)站提供《XPHY I/O同步接口應(yīng)用說明.pdf》資料免費下載
    發(fā)表于 09-13 14:46 ?0次下載
    XPHY <b class='flag-5'>I</b>/<b class='flag-5'>O</b>源<b class='flag-5'>同步</b>接口應(yīng)用說明

    同步異步通信協(xié)議介紹

    同步異步傳輸歸結(jié)為時鐘是外部的(同步)還是內(nèi)部的(異步)。異步協(xié)議的一些例子包括UART、USB、CAN和以太網(wǎng)。
    發(fā)表于 11-27 15:39 ?1560次閱讀
    <b class='flag-5'>同步</b>和<b class='flag-5'>異步</b>通信協(xié)議介紹

    異步電路和同步電路區(qū)別在哪?

    部分是獨立運行的,沒有明確定義的時鐘信號來同步它們的操作。相反,每個部分在滿足特定的條件下單獨啟動和運行,通過相互之間的通信來完成所需的協(xié)作。異步電路通常采用握手協(xié)議來確保數(shù)據(jù)的正確傳輸,即在發(fā)送方發(fā)送數(shù)據(jù)
    的頭像 發(fā)表于 12-07 10:53 ?3232次閱讀