一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

Linux的5種IO模型

FPGA之家 ? 來源:FPGA之家 ? 作者:FPGA之家 ? 2022-08-12 09:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

哈嘍,我是老吳,俺又來分享文章啦!

渾渾噩噩到了 30 歲,距離開滴滴還有 5 年的時間。

還有機會全身而退嗎?

哈哈!

30 而立,今年會是值得拼搏的一年,干它!

以下是正文:

一、Linux 的 5 種 IO 模型
二、如何使用信號驅(qū)動式 I/O?
三、內(nèi)核何時會發(fā)送 "IO 就緒" 信號?
四、最簡單的示例
五、擴展知識

一、Linux 的 5 種 IO 模型

阻塞式 I/O:

系統(tǒng)調(diào)用可能因為無法立即完成而被操作系統(tǒng)掛起,直到等待的事件發(fā)生為止。

1ad5174c-19db-11ed-ba43-dac502259ad0.png

點擊查看大圖

非阻塞式 I/O (O_NONBLOCK):

系統(tǒng)調(diào)用則總是立即返回,而不管事件是否已經(jīng)發(fā)生。

1ae66bb4-19db-11ed-ba43-dac502259ad0.png

點擊查看大圖

I/O 復(fù)用 (select、poll、epoll):

通過 I/O 復(fù)用函數(shù)向內(nèi)核注冊一組事件,內(nèi)核通過 I/O 復(fù)用函數(shù)把其中就緒的事件通知給應(yīng)用程序。

1af9df32-19db-11ed-ba43-dac502259ad0.png

點擊查看大圖

信號驅(qū)動式 I/O (SIGIO):

為一個目標文件描述符指定宿主進程,當文件描述符上有事件發(fā)生時,SIGIO 的信號處理函數(shù)將被觸發(fā),然后便可對目標文件描述符執(zhí)行 I/O 操作。

1b1c96da-19db-11ed-ba43-dac502259ad0.png

點擊查看大圖

異步 I/O (POSIX 的 aio_ 系列函數(shù)):

異步 I/O 的讀寫操作總是立即返回,而不論 I/O 是否是阻塞的,真正的讀寫操作由內(nèi)核接管。

1b327766-19db-11ed-ba43-dac502259ad0.png

點擊查看大圖

思考一下,什么時候應(yīng)該選擇何種 I/O 模型?為何要這么選擇?

下面重點關(guān)注信號驅(qū)動式 I/O 這一模型,其他模型可查閱文末參考書籍。

二、如何使用信號驅(qū)動式 I/O?

一般通過如下 6 個步驟來使用信號驅(qū)動式 I/O 模型。

1> 為通知信號安裝處理函數(shù)。

通過 sigaction() 來完成:

intsigaction(intsignum,conststructsigaction*act,structsigaction*oldact);

默認情況下,這個通知信號為 SIGIO。

2> 為文件描述符的設(shè)置屬主。

通過 fcntl() 的 F_SETOWN 操作來完成:

fcntl(fd,F_SETOWN,pid)

屬主是當文件描述符上可執(zhí)行 I/O 時,會接收到通知信號的進程或進程組。

pid 為正整數(shù)時,代表了進程 ID 號。

pid 為負整數(shù)時,它的絕對值就代表了進程組 ID 號。

3> 使能非阻塞 I/O。

通過 fcntl() 的 F_SETFL 操作來完成:

flags=fcntl(fd,F_GETFL);
fcntl(fd,F_SETFL,flags|O_NONBLOCK);

4> 使能信號驅(qū)動 I/O。

通過 fcntl() 的 F_SETFL 操作來完成:

flags=fcntl(fd,F_GETFL);
fcntl(fd,F_SETFL,flags|O_ASYNC);

5> 進程等待 "IO 就緒" 信號的到來。

當 I/O 操作就緒時,內(nèi)核會給進程發(fā)送一個信號,然后調(diào)用在第 1 步中安裝好的信號處理函數(shù)。

6> 進程盡可能多地執(zhí)行 I/O 操作。

循環(huán)執(zhí)行 I/O 系統(tǒng)調(diào)用直到失敗為止,此時錯誤碼為 EAGAIN 或 EWOULDBLOCK。

原因:

信號驅(qū)動 I/O 提供的是邊緣觸發(fā)通知,即只有當 I/O 事件發(fā)生時我們才會收到通知,

且當文件描述符收到 I/O 事件通知時,并不知道要處理多少 I/O 數(shù)據(jù)。

三、內(nèi)核何時會發(fā)送 "IO 就緒" 信號?

對于不同類型的文件描述符,情況不一樣。

1> 終端

  • 對于終端,當有新的輸入時會會產(chǎn)生信號。

2> 管道和 FIFO

對于讀端,下列情況會產(chǎn)生信號:

  • 數(shù)據(jù)寫入到管道中;
  • 管道的寫端關(guān)閉;

對于寫端,下列情況會產(chǎn)生信號:

  • 對管道的讀操作增加了管道中的空余空間大小。
  • 管道的讀端關(guān)閉;

3> 套接字

對于 UDP 套接字,下列情況會產(chǎn)生信號:

  • 數(shù)據(jù)報到達套接字;
  • 套接字上發(fā)生異步錯誤;

對于 TCP 套接字,信號驅(qū)動式 I/O 近乎無用。

  • 太多情況都會產(chǎn)生信號,而我們又無法得知事件類型,因此這里就不再列舉其產(chǎn)生信號的情況。

四、最簡單的示例

信號處理函數(shù):

staticvolatilesig_atomic_tgotSigio=0;

staticvoidhandler(intsig)
{
gotSigio=1;
}

主程序:

intmain(intargc,char*argv[])
{
intflags,j,cnt;
structtermiosorigTermios;
charch;
structsigactionsa;
intdone;

/*Establishhandler*/
sigemptyset(&sa.sa_mask);
sa.sa_flags=SA_RESTART;
sa.sa_handler=handler;
if(sigaction(SIGIO,&sa,NULL)==-1){
perror("sigaction()
");
exit(1);
}

/*Setownerprocess*/
if(fcntl(STDIN_FILENO,F_SETOWN,getpid())==-1){
perror("fcntl()/F_SETOWN
");
exit(1);
}

/*Enable"I/Opossible"signalingandmakeI/Ononblocking*/
flags=fcntl(STDIN_FILENO,F_GETFL);
if(fcntl(STDIN_FILENO,F_SETFL,flags|O_ASYNC|O_NONBLOCK)==-1){
perror("fcntl()/F_SETFL
");
exit(1);
}

for(done=0,cnt=0;!done;cnt++){
sleep(1);

if(gotSigio){
gotSigio=0;

/*Readallavailableinputuntilerror(probablyEAGAIN)
orEOF*/
while(read(STDIN_FILENO,&ch,1)>0&&!done){
printf("cnt=%d;read%c
",cnt,ch);
done=ch=='#';
}
}
}
exit(0);
}

運行效果:

./build/sigio
a
cnt=0;reada
cnt=0;read

abc
cnt=4;reada
cnt=4;readb
cnt=4;readc
cnt=4;read

#
cnt=7;read#

該程序會先使能信號驅(qū)動 IO,然后循環(huán)執(zhí)行計數(shù)操作。

當有 IO 就緒信號到來時,會去終端讀取數(shù)據(jù)并打印出來,然后繼續(xù)執(zhí)行計數(shù)操作。

五、擴展知識

I/O 多路復(fù)用 、信號驅(qū)動 I/O 以及 epoll 機制可用于監(jiān)視多個文件描述符。

它們并不實際執(zhí)行 I/O 操作,當某個文件描述符處于就緒態(tài),仍需采用傳統(tǒng)的 I/O 系統(tǒng)調(diào)用來完成 I/O 操作。

相比 I/O 多路復(fù)用,當監(jiān)視大量的文件描述符時信號驅(qū)動 I/O 有著顯著的性能優(yōu)勢,原因是內(nèi)核能夠幫進程記錄了正在監(jiān)視的文件描述符列表。

信號驅(qū)動 I/O 的缺點:

  • 信號的處理流程較為復(fù)雜;

  • 無法指定需要監(jiān)控的事件類型。

Linux 特有的 epoll 是一個更好的選擇。

六、相關(guān)參考

UNIX 網(wǎng)絡(luò)編程卷1

  • 6.2 I/O模型
  • 25 信號驅(qū)動式I/O

Linux-UNIX 系統(tǒng)編程手冊

  • 63 其他備選的I/O模型

Linux 高性能服務(wù)器編程

  • 8.3 I/O 模型

Linux 多線程服務(wù)端編程_使用muduo C++網(wǎng)絡(luò)庫

  • 7.4.1 muduo的IO模型

審核編輯 :李倩



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

    關(guān)注

    87

    文章

    11511

    瀏覽量

    213863
  • 信號處理
    +關(guān)注

    關(guān)注

    48

    文章

    1056

    瀏覽量

    104110
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4381

    瀏覽量

    64921

原文標題:思考技術(shù),也思考人生

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    Analog Devices / Maxim Integrated MAXREFDES177 IO-Link通用模擬IO特性/框圖

    Analog Devices MAXREFDES177 IO-Link通用模擬IO是一款完備的IO-Link?通用模擬輸入-輸出 (IO) 參考設(shè)計,采用內(nèi)置集成保護功能的MAX225
    的頭像 發(fā)表于 06-30 09:30 ?149次閱讀
    Analog Devices / Maxim Integrated MAXREFDES177 <b class='flag-5'>IO</b>-Link通用模擬<b class='flag-5'>IO</b>特性/框圖

    OpenAI即將推出GPT-5模型

    OpenAI首席執(zhí)行官奧爾特曼近日宣布了一項重要消息:OpenAI將在今年未來幾個月內(nèi)推出全新的GPT-5模型。這一消息引起了業(yè)界的廣泛關(guān)注和期待。 據(jù)了解,GPT-5模型將整合Ope
    的頭像 發(fā)表于 02-13 11:21 ?596次閱讀

    請問有沒有不在linux上對.pt模型向.kmodel轉(zhuǎn)換的教程呢?

    1、請問有沒有不在linux上對.pt模型向.kmodel轉(zhuǎn)換的教程呢? 我看網(wǎng)上有個nncase studio的教程(AI模型GUI編譯工具 nncase studio食用指南 - Homura
    發(fā)表于 02-08 08:56

    λ-IO:存儲計算下的IO棧設(shè)計

    動機和背景? ? 存儲計算存儲資源的充分利用。IO棧是管理存儲器的的基本組件,包括設(shè)備驅(qū)動、塊接口層、文件系統(tǒng),目前一些用戶空間IO庫(如SPDK)有效降低了延遲,但是io棧仍然不可或缺。這是因為1
    的頭像 發(fā)表于 12-02 10:35 ?641次閱讀
    λ-<b class='flag-5'>IO</b>:存儲計算下的<b class='flag-5'>IO</b>棧設(shè)計

    一文解讀Linux 5IO模型

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

    Linux--IO多路復(fù)用(select,poll,epoll)

    IO多路復(fù)用——select,poll,epollIO多路復(fù)用是一操作系統(tǒng)技術(shù),旨在提高系統(tǒng)處理多個輸入輸出操作的性能和資源利用率。與傳統(tǒng)的多線程或多進程模型相比,IO多路復(fù)用避免了
    的頭像 發(fā)表于 11-06 16:13 ?1041次閱讀

    華納云監(jiān)視Linux磁盤IO性能命令:iotop,iostat,vmstat,atop,dstat,ioping

    以下介紹6個監(jiān)視 Linux 磁盤IO性能的命令(工具),它們分別是iotop、iostat、vmstat、atop、dstat、ioping,以下將附上簡單的使用方法。 前言 磁盤IO
    的頭像 發(fā)表于 10-24 14:43 ?713次閱讀

    MR20遠程IOIO-Link的差異化應(yīng)用

    在工業(yè)自動化領(lǐng)域,遠程IO)和IO-Link作為兩重要的通信協(xié)議,各自扮演著不可或缺的角色。盡管它們都是為了實現(xiàn)設(shè)備之間的數(shù)據(jù)傳輸與控制,但在應(yīng)用場景、系統(tǒng)架構(gòu)和功能特點上卻存在著顯著的差異。本文
    的頭像 發(fā)表于 10-21 17:29 ?622次閱讀

    本地IO與遠程IO:揭秘工業(yè)自動化中的兩大關(guān)鍵角色

    在工業(yè)自動化領(lǐng)域,IO(Input/Output,輸入/輸出)模塊扮演著至關(guān)重要的角色。它們作為連接控制系統(tǒng)與現(xiàn)場設(shè)備的橋梁,負責數(shù)據(jù)的采集與指令的執(zhí)行。然而,隨著技術(shù)的不斷進步,IO模塊也分為本地IO和遠程
    的頭像 發(fā)表于 10-08 18:06 ?1130次閱讀

    解析一體式IO與分布式IO:從架構(gòu)到應(yīng)用

    在工業(yè)自動化領(lǐng)域,IO(輸入/輸出)系統(tǒng)扮演著舉足輕重的角色。它們不僅負責數(shù)據(jù)的采集和控制指令的發(fā)送,還直接影響到系統(tǒng)的靈活性、可靠性和成本效益。明達技術(shù)將為您介紹一體式IO和分布式IO在架構(gòu)及應(yīng)用層的主要區(qū)別,幫助您更好地理解
    的頭像 發(fā)表于 10-08 10:02 ?855次閱讀
    解析一體式<b class='flag-5'>IO</b>與分布式<b class='flag-5'>IO</b>:從架構(gòu)到應(yīng)用

    Linux應(yīng)用層控制外設(shè)的兩不同的方式

    眾所周知,linux下一切皆文件,那么應(yīng)用層如何控制硬件層,同樣是通過 文件I/O的方式來實現(xiàn)的,那么應(yīng)用層控制硬件層通常有兩方式。
    的頭像 發(fā)表于 10-05 19:03 ?1352次閱讀
    <b class='flag-5'>Linux</b>應(yīng)用層控制外設(shè)的兩<b class='flag-5'>種</b>不同的方式

    請問如何將HSPICE和 IBIS兩模型怎么轉(zhuǎn)換成TINA軟件中用?

    TI網(wǎng)站里,給出了一些期間的HSPICE和IBIS模型,但是現(xiàn)有的仿真工具 只有TINA這種,請問如何將HSPICE和 IBIS兩模型怎么轉(zhuǎn)換成TINA軟件中用? 請高手給予解答。感謝!
    發(fā)表于 09-02 07:56

    linux驅(qū)動程序如何加載進內(nèi)核

    ,需要了解Linux內(nèi)核的基本概念和API。以下是一些關(guān)鍵概念: 1.1 內(nèi)核模塊:Linux內(nèi)核模塊是一動態(tài)加載和卸載的代碼,可以在不重新啟動系統(tǒng)的情況下加載和卸載。驅(qū)動程序通常以內(nèi)核模塊的形式實現(xiàn)。 1.2 設(shè)備
    的頭像 發(fā)表于 08-30 15:02 ?1108次閱讀

    Linux磁盤IO詳細解析

      在講解磁盤IO前,先簡單說下什么是磁盤。磁盤是可以持久化存儲的設(shè)備,根據(jù)存儲介質(zhì)的不同,常見磁盤可以分為兩類:機械磁盤和固態(tài)磁盤。
    的頭像 發(fā)表于 08-05 15:49 ?1105次閱讀
    <b class='flag-5'>Linux</b>磁盤<b class='flag-5'>IO</b>詳細解析

    LM393A的Pspice模型為什么只有5個引腳?

    如上右圖時Pspice模型,只有5個引腳,且沒有8引腳,怎么添加電源
    發(fā)表于 07-29 07:32