久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學習站 | 隨時隨地免費學

        千鋒教育

        掃一掃進入千鋒手機站

        領取全套視頻
        千鋒教育

        關注千鋒學習站小程序
        隨時隨地免費學習課程

        當前位置:首頁  >  技術(shù)干貨  > Python中sellect、poll、epoll三者的區(qū)別

        Python中sellect、poll、epoll三者的區(qū)別

        來源:千鋒教育
        發(fā)布人:xqq
        時間: 2023-11-07 14:31:34 1699338694

        select

        select最早于1983年出現(xiàn)在4.2BSD中,它通過一個select()系統(tǒng)調(diào)用來監(jiān)視多個文件描述符的數(shù)組,當select()返回后,該數(shù)組中就緒的文件描述符便會被內(nèi)核修改標志位,使得進程可以獲得這些文件描述符從而進行后續(xù)的讀寫操作。

        select目前幾乎在所有的平臺上支持,其良好跨平臺支持也是它的一個優(yōu)點,事實上從現(xiàn)在看來,這也是它所剩不多的優(yōu)點之一。

        select的一個缺點在于單個進程能夠監(jiān)視的文件描述符的數(shù)量存在最大限制,在Linux上一般為1024,不過可以通過修改宏定義甚至重新編譯內(nèi)核的方式提升這一限制。

        另外,select()所維護的存儲大量文件描述符的數(shù)據(jù)結(jié)構(gòu),隨著文件描述符數(shù)量的增大,其復制的開銷也線性增長。同時,由于網(wǎng)絡響應時間的延遲使得大量TCP連接處于非活躍狀態(tài),但調(diào)用select()會對所有socket進行一次線性掃描,所以這也浪費了一定的開銷。

        poll

        poll在1986年誕生于SystemVRelease3,它和select在本質(zhì)上沒有多大差別,但是poll沒有最大文件描述符數(shù)量的限制。

        poll和select同樣存在一個缺點就是,包含大量文件描述符的數(shù)組被整體復制于用戶態(tài)和內(nèi)核的地址空間之間,而不論這些文件描述符是否就緒,它的開銷隨著文件描述符數(shù)量的增加而線性增大。

        另外,select()和poll()將就緒的文件描述符告訴進程后,如果進程沒有對其進行IO操作,那么下次調(diào)用select()和poll()的時候?qū)⒃俅螆蟾孢@些文件描述符,所以它們一般不會丟失就緒的消息,這種方式稱為水平觸發(fā)(LevelTriggered)。

        epoll

        直到Linux2.6才出現(xiàn)了由內(nèi)核直接支持的實現(xiàn)方法,那就是epoll,它幾乎具備了之前所說的一切優(yōu)點,被公認為Linux2.6下性能最好的多路I/O就緒通知方法。

        epoll可以同時支持水平觸發(fā)和邊緣觸發(fā)(EdgeTriggered,只告訴進程哪些文件描述符剛剛變?yōu)榫途w狀態(tài),它只說一遍,如果我們沒有采取行動,那么它將不會再次告知,這種方式稱為邊緣觸發(fā)),理論上邊緣觸發(fā)的性能要更高一些,但是代碼實現(xiàn)相當復雜。

        epoll同樣只告知那些就緒的文件描述符,而且當我們調(diào)用epoll_wait()獲得就緒文件描述符時,返回的不是實際的描述符,而是一個代表就緒描述符數(shù)量的值,你只需要去epoll指定的一個數(shù)組中依次取得相應數(shù)量的文件描述符即可,這里也使用了內(nèi)存映射(mmap)技術(shù),這樣便徹底省掉了這些文件描述符在系統(tǒng)調(diào)用時復制的開銷。

        另一個本質(zhì)的改進在于epoll采用基于事件的就緒通知方式。在select/poll中,進程只有在調(diào)用一定的方法后,內(nèi)核才對所有監(jiān)視的文件描述符進行掃描,而epoll事先通過epoll_ctl()來注冊一個文件描述符,一旦基于某個文件描述符就緒時,內(nèi)核會采用類似callback的回調(diào)機制,迅速激活這個文件描述符,當進程調(diào)用epoll_wait()時便得到通知。

        使用select:

        在python中,select函數(shù)是一個對底層操作系統(tǒng)的直接訪問的接口。它用來監(jiān)控sockets、files和pipes,等待IO完成(WaitingforI/Ocompletion)。當有可讀、可寫或是異常事件產(chǎn)生時,select可以很容易的監(jiān)控到。

        select.select(rlist,wlist,xlist[,timeout])傳遞三個參數(shù),一個為輸入而觀察的文件對象列表,一個為輸出而觀察的文件對象列表和一個觀察錯誤異常的文件列表。第四個是一個可選參數(shù),表示超時秒數(shù)。其返回3個tuple,每個tuple都是一個準備好的對象列表,它和前邊的參數(shù)是一樣的順序。下面,主要結(jié)合代碼,簡單說說select的使用。

        Server端程序:

        1、該程序主要是利用socket進行通信,接收客戶端發(fā)送過來的數(shù)據(jù),然后再發(fā)還給客戶端。

        2、首先建立一個TCP/IPsocket,并將其設為非阻塞,然后進行bind和listen。

        3、通過select函數(shù)獲取到三種文件列表,分別對每個列表的每個元素進行輪詢,對不同socket進行不同的處理,最外層循環(huán)直到inputs列表為空為止

        4、當設置timeout參數(shù)時,如果發(fā)生了超時,select函數(shù)會返回三個空列表。

        以上內(nèi)容為大家介紹了Python中sellect、poll、epoll三者的區(qū)別,希望對大家有所幫助,如果想要了解更多Python相關知識,請關注IT培訓機構(gòu):千鋒教育。

        tags: python培訓
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
        免費領取
        今日已有369人領取成功
        劉同學 138****2860 剛剛成功領取
        王同學 131****2015 剛剛成功領取
        張同學 133****4652 剛剛成功領取
        李同學 135****8607 剛剛成功領取
        楊同學 132****5667 剛剛成功領取
        岳同學 134****6652 剛剛成功領取
        梁同學 157****2950 剛剛成功領取
        劉同學 189****1015 剛剛成功領取
        張同學 155****4678 剛剛成功領取
        鄒同學 139****2907 剛剛成功領取
        董同學 138****2867 剛剛成功領取
        周同學 136****3602 剛剛成功領取
        相關推薦HOT
        Python之select、poll、epoll模型的區(qū)別

        select、poll、epoll模型的區(qū)別?(屬于多路復用IO的模型)都是i/o多路復用的機制,監(jiān)視多個socket是否發(fā)生變化,本質(zhì)上都是同步i/oselect,poll實...詳情>>

        2023-11-07 17:31:34
        Python進程、線程、協(xié)程的區(qū)別

        簡述進程、線程、協(xié)程的區(qū)別以及應用場景?線程是指進程內(nèi)的一個執(zhí)行單元,#進程進程擁有自己獨立的堆和棧,既不共享堆,亦不共享棧,進程由操作...詳情>>

        2023-11-07 17:27:58
        簡述Python數(shù)據(jù)庫三大范式?

        python數(shù)據(jù)庫的三大特性:'實體':表'屬性':表中的數(shù)據(jù)(字段)'關系':表與表之間的關系----------------------------...詳情>>

        2023-11-07 17:24:22
        列舉python常見的內(nèi)置函數(shù)

        abs()返回數(shù)字的絕對值map根據(jù)函數(shù)對指定序列做映射map()函數(shù)接收兩個參數(shù),一個是函數(shù),一個是可迭代對象,map將傳入的函數(shù)依次作用到序列的每...詳情>>

        2023-11-07 17:02:46
        python內(nèi)置函數(shù):map、reduce、filter的用法和區(qū)別

        map:根據(jù)函數(shù)對指定序列做映射map參數(shù)接收兩個參數(shù):一個是函數(shù),一個是序列(可迭代對象)返回值Python2返回列表python3返回迭代器#例子:#abs()...詳情>>

        2023-11-07 16:59:10
        青龙| 凯里市| 禄丰县| 琼中| 淮北市| 舒城县| 杭州市| 禄丰县| 雷波县| 芜湖市| 梁河县| 浑源县| 六盘水市| 浙江省| 原阳县| 体育| 栾城县| 襄汾县| 砀山县| 岳池县| 安乡县| 喀喇沁旗| 贵南县| 盱眙县| 兰溪市| 望江县| 宾川县| 肃北| 西乡县| 南漳县| 五寨县| 建瓯市| 封丘县| 尉氏县| 博客| 永兴县| 陇南市| 芮城县| 太康县| 通州区| 什邡市|