日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

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

Linux愛好者 ? 來源:lq ? 2019-04-27 18:19 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

同步阻塞,小明去火車站買票。首先,他需要在某一個售票窗口排隊,當輪到他買票時,他需要告訴售票員他需要一張去上海的火車票,然后售票員需要去系統(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ù)準備就緒,系統(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)準備就緒,即輪詢(polling)。輪詢往往會消耗大量的CPU時間。

下圖中,用戶進程發(fā)起recvfrom系統(tǒng)調(diào)用,由于系統(tǒng)內(nèi)核中數(shù)據(jù)尚未就緒,內(nèi)核會立即返回EWOULDBLOCK錯誤碼,防止用戶進程阻塞。如此往復(fù),直到系統(tǒng)內(nèi)核中數(shù)據(jù)準備就緒。在數(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ù)為例,當我們調(diào)用該函數(shù)時,用戶進程將阻塞,直到系統(tǒng)內(nèi)核中的數(shù)據(jù)準備好。數(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

    文章

    8340

    瀏覽量

    95600
  • UNIX
    +關(guān)注

    關(guān)注

    0

    文章

    296

    瀏覽量

    43167
  • Posix
    +關(guān)注

    關(guān)注

    0

    文章

    36

    瀏覽量

    10130

原文標題: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 ?3320次閱讀
    【<b class='flag-5'>i</b>.MX6ULL】驅(qū)動開發(fā)9——Linux <b class='flag-5'>I</b>/<b class='flag-5'>O</b>模型分析并進來類比

    飛凌嵌入式ElfBoard-文件I/O的深入學(xué)習(xí)之異步I/O

    I/O多路復(fù)用中,進程通過系統(tǒng)調(diào)用select或poll來主動查詢文件描述符上是否可以執(zhí)行I/O操作。而在異步
    發(fā)表于 12-05 11:23

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

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

    本文開始對異步傳輸進行了介紹,其中包括了異步傳輸工作原理和異步傳輸模式,其次介紹了同步傳輸?shù)?b class='flag-5'>定義和特點,最后詳細介紹了
    發(fā)表于 03-02 14:09 ?1.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 ?2509次閱讀

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

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

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

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

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

    電子發(fā)燒友網(wǎng)站提供《XPHY I/O同步接口應(yīng)用說明.pdf》資料免費下載
    發(fā)表于 09-13 14:46 ?1次下載
    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 ?2822次閱讀
    <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 ?5670次閱讀

    I/O接口與I/O端口的區(qū)別

    在計算機系統(tǒng)中,I/O接口與I/O端口是實現(xiàn)CPU與外部設(shè)備數(shù)據(jù)交換的關(guān)鍵組件,它們在功能、結(jié)構(gòu)、作用及運作機制上均存在顯著差異,卻又相互協(xié)同工作,共同構(gòu)建起CPU與外部設(shè)備之間的橋梁
    的頭像 發(fā)表于 02-02 16:00 ?3826次閱讀
    蓬安县| 扶沟县| 廊坊市| 和政县| 寿宁县| 江华| 邳州市| 思茅市| 余江县| 安国市| 武宣县| 疏附县| 平南县| 封丘县| 临颍县| 沅陵县| 郧西县| 文昌市| 濮阳市| 玉山县| 开化县| 时尚| 邵阳县| 大田县| 五台县| 资源县| 杂多县| 洪湖市| 民勤县| 奉贤区| 共和县| 绥江县| 海门市| 凤台县| 集贤县| 沙洋县| 西青区| 青河县| 行唐县| 萍乡市| 温宿县|