女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

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

Linux的5種IO模型

FPGA之家 ? 來源:FPGA之家 ? 作者:FPGA之家 ? 2022-08-12 09:22 ? 次閱讀

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

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

還有機(jī)會全身而退嗎?

哈哈!

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

以下是正文:

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

一、Linux 的 5 種 IO 模型

阻塞式 I/O:

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

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

點(diǎn)擊查看大圖

非阻塞式 I/O (O_NONBLOCK):

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

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

點(diǎn)擊查看大圖

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

點(diǎn)擊查看大圖

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

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

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

點(diǎn)擊查看大圖

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

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

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

點(diǎn)擊查看大圖

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

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

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

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

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

通過 sigaction() 來完成:

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

默認(rèn)情況下,這個通知信號為 SIGIO。

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

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

fcntl(fd,F_SETOWN,pid)

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

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

pid 為負(fù)整數(shù)時,它的絕對值就代表了進(jìn)程組 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> 進(jìn)程等待 "IO 就緒" 信號的到來。

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

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

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

原因:

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

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

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

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

1> 終端

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

2> 管道和 FIFO

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

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

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

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

3> 套接字

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

  • 數(shù)據(jù)報到達(dá)套接字;
  • 套接字上發(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);
}

運(yùn)行效果:

./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ù)操作。

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

五、擴(kuò)展知識

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

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

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

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

  • 信號的處理流程較為復(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)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11456

    瀏覽量

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

    關(guān)注

    48

    文章

    1055

    瀏覽量

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

    關(guān)注

    3

    文章

    4367

    瀏覽量

    64155

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

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

收藏 人收藏

    評論

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

    OpenAI即將推出GPT-5模型

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

    請問有沒有不在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è)計

    動機(jī)和背景? ? 存儲計算存儲資源的充分利用。IO棧是管理存儲器的的基本組件,包括設(shè)備驅(qū)動、塊接口層、文件系統(tǒng),目前一些用戶空間IO庫(如SPDK)有效降低了延遲,但是io棧仍然不可或缺。這是因為1
    的頭像 發(fā)表于 12-02 10:35 ?550次閱讀
    λ-<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 ?780次閱讀
    一文解讀<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)的多線程或多進(jìn)程模型相比,IO多路復(fù)用避免了
    的頭像 發(fā)表于 11-06 16:13 ?849次閱讀

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

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

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

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

    在工業(yè)自動化領(lǐng)域,IO(輸入/輸出)系統(tǒng)扮演著舉足輕重的角色。它們不僅負(fù)責(zé)數(shù)據(jù)的采集和控制指令的發(fā)送,還直接影響到系統(tǒng)的靈活性、可靠性和成本效益。明達(dá)技術(shù)將為您介紹一體式IO和分布式IO在架構(gòu)及應(yīng)用層的主要區(qū)別,幫助您更好地理解
    的頭像 發(fā)表于 10-08 10:02 ?695次閱讀
    解析一體式<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的方式來實(shí)現(xiàn)的,那么應(yīng)用層控制硬件層通常有兩方式。
    的頭像 發(fā)表于 10-05 19:03 ?1176次閱讀
    <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ū)動程序如何加載進(jìn)內(nèi)核

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

    Linux磁盤IO詳細(xì)解析

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

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

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

    一體式IO與分布式IO:工業(yè)控制系統(tǒng)的兩架構(gòu)

    受到青睞。然而,一體式IO架構(gòu)在小型系統(tǒng)中仍然有著廣泛的應(yīng)用。了解這兩架構(gòu)的特點(diǎn)和區(qū)別,有助于工程師和決策者為企業(yè)選擇最合適的工業(yè)控制系統(tǒng)解決方案。
    的頭像 發(fā)表于 07-17 16:12 ?1887次閱讀
    一體式<b class='flag-5'>IO</b>與分布式<b class='flag-5'>IO</b>:工業(yè)控制系統(tǒng)的兩<b class='flag-5'>種</b>架構(gòu)

    遠(yuǎn)程IO與分布式IO的區(qū)別

    在工業(yè)自動化和控制系統(tǒng)設(shè)計中,遠(yuǎn)程IO(Input/Output)和分布式IO是兩個重要的概念。它們各自具有獨(dú)特的特點(diǎn)和優(yōu)勢,適用于不同的應(yīng)用場景。本文將詳細(xì)探討遠(yuǎn)程IO與分布式IO
    的頭像 發(fā)表于 06-15 15:57 ?3739次閱讀