99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

3天內不再提示

Linux的5種IO模型

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

掃碼添加小助手

加入工程師交流群

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

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

還有機會全身而退嗎?

哈哈!

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

以下是正文:

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

一、Linux 的 5 種 IO 模型

阻塞式 I/O:

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

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

點擊查看大圖

非阻塞式 I/O (O_NONBLOCK):

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

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

點擊查看大圖

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

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

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

點擊查看大圖

信號驅動式 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 是否是阻塞的,真正的讀寫操作由內核接管。

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

點擊查看大圖

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

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

二、如何使用信號驅動式 I/O?

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

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

通過 sigaction() 來完成:

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

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

2> 為文件描述符的設置屬主。

通過 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> 使能信號驅動 I/O。

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

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

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

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

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

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

原因:

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

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

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

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

1> 終端

  • 對于終端,當有新的輸入時會會產生信號。

2> 管道和 FIFO

對于讀端,下列情況會產生信號:

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

對于寫端,下列情況會產生信號:

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

3> 套接字

對于 UDP 套接字,下列情況會產生信號:

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

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

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

四、最簡單的示例

信號處理函數(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#

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

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

五、擴展知識

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

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

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

信號驅動 I/O 的缺點:

  • 信號的處理流程較為復雜;

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

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

六、相關參考

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

  • 6.2 I/O模型
  • 25 信號驅動式I/O

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

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

Linux 高性能服務器編程

  • 8.3 I/O 模型

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

  • 7.4.1 muduo的IO模型

審核編輯 :李倩



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

    關注

    87

    文章

    11511

    瀏覽量

    213838
  • 信號處理
    +關注

    關注

    48

    文章

    1056

    瀏覽量

    104107
  • 函數(shù)
    +關注

    關注

    3

    文章

    4381

    瀏覽量

    64898

原文標題:思考技術,也思考人生

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    OpenAI即將推出GPT-5模型

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

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

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

    λ-IO:存儲計算下的IO棧設計

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

    一文解讀Linux 5IO模型

    Linux里有五IO模型:阻塞IO、非阻塞IO、多路復用I
    的頭像 發(fā)表于 11-09 11:12 ?864次閱讀
    一文解讀<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多路復用(select,poll,epoll)

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

    華納云監(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 ?711次閱讀

    MR20遠程IOIO-Link的差異化應用

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

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

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

    解析一體式IO與分布式IO:從架構到應用

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

    Linux應用層控制外設的兩不同的方式

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

    歐姆龍PLC數(shù)據(jù) 轉 profinet IO項目案例

    目錄 1 案例說明 1 2 VFBOX網(wǎng)關工作原理 1 3 準備工作 2 4 網(wǎng)關采集歐姆龍PLC數(shù)據(jù) 2 5 用PROFINET IO協(xié)議轉發(fā)數(shù)據(jù) 5 6 案例總結 7 1 案例說明 設置網(wǎng)關采集
    的頭像 發(fā)表于 09-27 10:06 ?607次閱讀
    歐姆龍PLC數(shù)據(jù) 轉 profinet <b class='flag-5'>IO</b>項目案例

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

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

    linux驅動程序如何加載進內核

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

    Linux磁盤IO詳細解析

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

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

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