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

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

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

IO多路復(fù)用基本概念

科技綠洲 ? 來源:Linux開發(fā)架構(gòu)之路 ? 作者:Linux開發(fā)架構(gòu)之路 ? 2023-11-10 16:34 ? 次閱讀

一、IO多路復(fù)用基本概念

select、poll、epoll都是IO多路復(fù)用的機制。IO多路復(fù)用就是通過一種機制,讓一個進程/線程可以監(jiān)視多個描述符,一旦某個描述符就緒(一般是讀寫就緒),能夠通知應(yīng)用程序進行相應(yīng)的讀寫操作。

I/O多路復(fù)用在英文叫 I/O multiplexing,這里面的 multiplexing 指的其實是在單個進程/線程通過記錄跟蹤每一個文件描述符的狀態(tài)來同時管理多個I/O流。發(fā)明它的原因,是盡可能地提高服務(wù)器的吞吐能力。

I/O復(fù)用雖然能同時監(jiān)聽多個文件描述符,當其本質(zhì)上還是同步IO模型,因為需要在讀寫事件就緒后程序自己負責進行讀寫事件的處理,而這個讀寫過程是阻塞的。如果要實現(xiàn)并發(fā),只能使用多進程/多線程等編程手段了。與多進程/多線程技術(shù)相比,I/O多路復(fù)用技術(shù)最大的優(yōu)勢就是系統(tǒng)開銷小,系統(tǒng)不必創(chuàng)建大量進程/線程,也不必維護這些進程/線程,從而大大減少了系統(tǒng)的開銷。

IO多路復(fù)用使用場景

1)當客戶處理多個描述符時(一般是交互式輸入和網(wǎng)絡(luò)接口),必須使用I/O復(fù)用。

2)當一個客戶同時處理多個套接口時,這種情況是可能的,但很少出現(xiàn)。

3)如果一個TCP服務(wù)器既要處理監(jiān)聽套接口,又要處理已連接套接口,一般也要用到I/O復(fù)用。

4)如果一個服務(wù)器即要處理TCP,又要處理UDP,一般要使用I/O復(fù)用。

5)如果一個服務(wù)器要處理多個服務(wù)或多個協(xié)議,一般要使用I/O復(fù)用。

二、三組 I/O 多路復(fù)用函數(shù)的比較

這三組I/O多路復(fù)用系統(tǒng)調(diào)用都能同時監(jiān)聽多個文件描述符。它們將等待由timeout參數(shù)指定的超時時間,直到一個或多個文件描述符上有事件發(fā)生時返回,返回值是就緒的文件描述符的數(shù)量,如果返回0,則表示沒有事件發(fā)生。

下面我們主要從事件集合、最大支持文件描述符數(shù)量、工作模式和底層實現(xiàn)原理等4個方面進一步比較它們的異同。

事件集合

這3組函數(shù)都通過某種結(jié)構(gòu)體變量來告訴內(nèi)核監(jiān)聽哪些文件描述符上的哪些事件,并使用該結(jié)構(gòu)體類型的參數(shù)來獲取內(nèi)核的處理結(jié)果。

select:使用 fd_set 結(jié)構(gòu)體來存放被監(jiān)聽的文件描述符的,本質(zhì)上是使用一個位圖結(jié)構(gòu)來存放這些被監(jiān)聽的文件描述符的,因此select能夠監(jiān)聽的文件描述符數(shù)量是有限制的。同時,fd_set 沒有將文件描述符和事件進行綁定,它僅僅是一個文件描述符集合,因此,select需要提供3個fd_set類型的參數(shù)來分別傳入和傳出可讀、可寫及異常事件。一方面,使得select不能處理更多類型的事件,另一方面,由于內(nèi)核對fd_set集合的在線修改,使得下次再調(diào)用select()函數(shù)前不得不重置這3個fd_set集合,這使得編程變成很麻煩,并且容易出錯。

poll:使用 struct pollfd結(jié)構(gòu)體來存放被監(jiān)聽的文件描述符,它比select“聰明”的地方就在于它把文件描述符和與其關(guān)聯(lián)的事件都定義在這個結(jié)構(gòu)體中了,從而使得編程接口變得簡潔很多,同時內(nèi)核每次修改的都是pollfd結(jié)構(gòu)體的revents成員,而events成員保持不變,因此下次調(diào)用poll()函數(shù)時應(yīng)用程序無須重置pollfd類型的事件集參數(shù)。

由于每次select 和 poll 調(diào)用都是返回整個用戶監(jiān)聽的事件集合(其中包括就緒的和未就緒的),所以應(yīng)用程序索引就緒文件描述符的時間復(fù)雜度為O(n)。

epoll:采用與select 和 poll 完全不同的方式來管理用戶注冊的事件。它在內(nèi)核中維護一個事件表,并提供了一個獨立的系統(tǒng)調(diào)用函數(shù) epoll_ctl來控制往該內(nèi)核事件表中添加、刪除、修改事件。這樣,每次調(diào)用epoll_wait()函數(shù)時,都是直接從內(nèi)核事件表中取得用戶注冊的事件,而無須反復(fù)從用戶空間將這些注冊事件讀入到內(nèi)核區(qū)中,節(jié)省了復(fù)制的系統(tǒng)開銷。epoll_wait 系統(tǒng)調(diào)用中的 events 指針參數(shù)僅用來返回就緒的事件,這使得應(yīng)用程序索引就緒文件描述符的時間復(fù)雜度為O(1)。需要注意的是,epoll 和 poll一樣,也是將文件描述符和與其關(guān)聯(lián)的事件是綁定在一起的,這樣做的好處是,編程接口變得簡潔,不像select那樣復(fù)雜。

最大支持文件描述符數(shù)量

poll 和 epoll 分別用 nfds 和 maxevents 參數(shù)指定最多監(jiān)聽多少個文件描述符。這兩個數(shù)值都能達到系統(tǒng)允許打開的最大文件描述符數(shù)目,即 65 535(cat /proc/sys/fs/file-max)。而select允許監(jiān)聽的最大文件描述符數(shù)量通常是有限的。雖然用戶可以修改這個限制,但是這可能會導(dǎo)致不可預(yù)期的后果。

工作模式

select 和 poll 都只能工作在相對低效的LT(水平觸發(fā))模式,而epoll 雖然默認也是工作在LT模式下,但是它還可以工作在更高效的ET(邊緣觸發(fā))模式下。并且 epoll 還支持 EPOLLONESHOT事件。該事件能進一步減少可讀、可寫和異常事件被觸發(fā)的次數(shù)。

底層實現(xiàn)原理

select 和 poll 都是采用輪詢的方式,即每次調(diào)用都要掃描整個注冊的文件描述符,并將其中就緒文件描述符的數(shù)量返回給應(yīng)用程序,因此它們檢測就緒文件描述符的事件復(fù)雜度為O(n)。

而epoll則不同,它采用的是回調(diào)的方式,內(nèi)核檢測到就緒的文件描述符時,將觸發(fā)回調(diào)函數(shù),回調(diào)函數(shù)就將該文件描述符上對應(yīng)的事件插入到內(nèi)核就緒事件隊列。當調(diào)用epoll_wait 系統(tǒng)調(diào)用時,無須輪詢整個內(nèi)核事件表中的文件描述符,而只需檢測就緒事件隊列是否有內(nèi)容,如有,內(nèi)核則將該就緒隊列中的內(nèi)容拷貝到用戶空間,因此epoll檢測就緒文件描述符的時間復(fù)雜度為O(1)。

三、三組 I/O 多路復(fù)用的優(yōu)缺點

3.1 select

【優(yōu)點】

1、select的可移植性好,因為在某些Unix系統(tǒng)上并不支持poll 和 epoll(極少)。

2、select 對于超時時間提供了更好的精度:微秒,而 poll 和 epoll 都是毫秒級。

【缺點】

1、select 支持監(jiān)聽的文件描述符fd的數(shù)量有限制,默認是1024個。(最大數(shù)量限制)

2、select 需要維護一個用來存放文件描述符fd的數(shù)據(jù)結(jié)構(gòu)(fd_set),每次調(diào)用select都需要把fd集合從用戶區(qū)拷貝到內(nèi)核區(qū),而select系統(tǒng)調(diào)用結(jié)束后,又需要把fd集合從內(nèi)核區(qū)拷貝到用戶區(qū),這個系統(tǒng)開銷在fd數(shù)量很多時會很大。(內(nèi)存復(fù)制開銷)

3、每次調(diào)用select系統(tǒng)調(diào)用時,都需要在內(nèi)核遍歷傳入的整個文件描述符集合,逐個檢測,查看是否有就緒的文件描述符,然后返回就緒文件描述符的個數(shù)。也就是說,select對文件描述符是線性掃描的,當注冊的文件描述符fd的數(shù)量很多時,效率會較低,時間復(fù)雜度為O(n)。(時間復(fù)雜度)

3.2 poll

poll的實現(xiàn)原理和select非常相似,但是相比select,它做了一些改進的地方。首先是存放文件描述符的數(shù)據(jù)結(jié)構(gòu)(pollfd),它將文件描述符和與其對應(yīng)的事件關(guān)聯(lián)起來了,使得編程接口變得簡潔了;其次,它沒有了最大文件描述符的限制,原因是它是基于鏈表結(jié)構(gòu)來存儲的。

【優(yōu)點】(對比select而言)

1、沒有最大文件描述符數(shù)量的限制(相對select而言)。(基于鏈表存儲)poll 主要是解決了這個最大文件描述符數(shù)量的限制問題。

當然,它還是有上限的,這個上限是操作系統(tǒng)所支持的能開啟的最大文件描述符數(shù)量(cat /proc/sys/fs/file-max)。

2、優(yōu)化了編程接口。select()函數(shù)有5個參數(shù),而poll()減少到了3個參數(shù)。并且每次調(diào)用select函數(shù)前,都必須重置該函數(shù)中的3個fd_set類型的參數(shù)值,而poll不需要重置。

【缺點】

1、poll 同樣需要維護一個用來存放文件描述符的數(shù)據(jù)結(jié)構(gòu)(pollfd),當注冊的文件描述符無數(shù)量很多時,會使得用戶區(qū)和內(nèi)核區(qū)之間傳遞該數(shù)據(jù)結(jié)構(gòu)的復(fù)制開銷很大。(內(nèi)存復(fù)制開銷)

每次調(diào)用poll系統(tǒng)調(diào)用時,都需要把文件描述符fd集合從用戶區(qū)拷貝到內(nèi)核區(qū),然后poll系統(tǒng)調(diào)用返回前,又需要把文件描述符fd集合從內(nèi)核區(qū)拷貝到用戶區(qū),這個內(nèi)存拷貝的系統(tǒng)開銷在fd數(shù)量很多的時候會很大。

<說明> 系統(tǒng)調(diào)用函數(shù)的執(zhí)行是發(fā)生在內(nèi)核區(qū)的,而用戶程序的執(zhí)行是發(fā)生在用戶區(qū)的,所以會存在內(nèi)核區(qū)與用戶區(qū)之間的內(nèi)存復(fù)制的系統(tǒng)開銷。

2、與select一樣,每次poll系統(tǒng)調(diào)用時,需要在內(nèi)核遍歷傳入的整個文件描述符集合,逐個檢測,查看是否有就緒的文件描述符,然后返回就緒文件描述符的個數(shù)。也就是說,poll也是線性掃描的方式,當注冊的文件描述符fd的數(shù)量很多時,效率會較低,時間復(fù)雜度為O(n)。(時間復(fù)雜度)

3、poll 只能工作在水平觸發(fā)(LT)模式下。(工作模式)

水平觸發(fā)模式下,當描述符處于就緒狀態(tài)下,內(nèi)核通知了應(yīng)用程序,但是應(yīng)用程序沒有進行處理,那么下次調(diào)用poll時仍會向應(yīng)用程序發(fā)出通知。

<注意> select 和 poll 都需要在返回后,通過遍歷整個文件描述符集合來獲取就緒的文件描述符。事實上,在網(wǎng)絡(luò)連接中,同時連接的大量客戶端在某一時刻可能只有很少的處于就緒狀態(tài),因此隨著監(jiān)視的描述符數(shù)量的遞增,其效率也會線性遞減。

3.3 epoll

epoll 是在Linux 2.6內(nèi)核版本中提出的,是之前select和poll的增強版本。

epoll使用一個epoll文件描述符管理多個被監(jiān)聽的文件描述符,將用戶關(guān)心的文件描述符的事件存放到內(nèi)核的一個事件表中,這樣在用戶區(qū)和內(nèi)核區(qū)只需要拷貝一次被監(jiān)聽的文件描述符的數(shù)據(jù)結(jié)構(gòu)(epoll_event)即可。

epoll 既解決了select的最大文件描述符數(shù)量限制的問題,又解決了poll的內(nèi)存復(fù)制開銷大、時間復(fù)雜度大的問題(前提條件:文件描述符數(shù)量很大的情況下)。

【優(yōu)點】(對比select和poll)

1、和poll一樣,沒有最大文件描述符數(shù)量的限制(相對select而言)。

2、epoll 雖然也需要維護用來存放文件描述符的數(shù)據(jù)結(jié)構(gòu)(epoll_event),但是它只需要將該數(shù)據(jù)結(jié)構(gòu)拷貝進內(nèi)核區(qū)一次,不需要重復(fù)拷貝。

epoll只在調(diào)用 epoll_ctl 系統(tǒng)調(diào)用時拷貝一次要監(jiān)聽的文件描述符數(shù)據(jù)結(jié)構(gòu)到內(nèi)核區(qū),在調(diào)用 epoll_wait系統(tǒng)調(diào)用時不需要再把所有要監(jiān)聽的文件描述符fd重復(fù)拷貝進內(nèi)核區(qū)。而select和poll每次調(diào)用都需要把所有要監(jiān)聽的fd重新拷貝到內(nèi)核區(qū)。這就解決了內(nèi)存復(fù)制開銷的問題。

3、epoll 采用回調(diào)方式來檢測就緒文件描述符。

epoll 通過epoll_ctl系統(tǒng)調(diào)用注冊一個文件描述符,一旦該文件描述符就緒,內(nèi)核就會采用callback回調(diào)機制來進行通知,并將該就緒描述符放入就緒事件鏈表中。然后在epoll_wait系統(tǒng)調(diào)用中,當接收到有通知信號到來時,就會去檢測就緒事件鏈表是否有內(nèi)容,如果有內(nèi)容,就將就緒事件鏈表的內(nèi)容從內(nèi)核區(qū)拷貝到用戶區(qū),最后epoll_wait系統(tǒng)調(diào)用返回就緒描述符的個數(shù)。也就是說,epoll只會對活躍的文件描述符進行管理,而不需要像select和poll那樣,每次調(diào)用都要線性掃描全部的文件描述符,導(dǎo)致效率呈現(xiàn)線性下降。

【缺點】

目前只有Linux操作系統(tǒng)支持epoll,不支持跨平臺使用。而Unix操作系統(tǒng)上是使用kqueue。

四、幾個需要注意的問題

4.1 用戶態(tài)將文件描述符參傳入內(nèi)核的方式

  • select:創(chuàng)建3個文件描述符集的數(shù)據(jù)結(jié)構(gòu)(fd_set)并拷貝到內(nèi)核中,分別監(jiān)聽讀、寫、異常事件。受單個進程/線程可以打開的文件描述符數(shù)量限制,默認是1024個文件描述符。
  • poll:將傳入的文件描述符數(shù)據(jù)結(jié)構(gòu)(struct pollfd結(jié)構(gòu)體數(shù)組)拷貝到內(nèi)核中進行監(jiān)聽。
  • epoll:執(zhí)行epoll_create系統(tǒng)調(diào)用時會在內(nèi)核的緩沖區(qū)中建立一顆紅黑樹以及就緒鏈表(該鏈表用于存儲已就緒的文件描述符)。接著用戶執(zhí)行的epoll_ctl系統(tǒng)調(diào)用添加文件描述符,即在紅黑樹上增加相應(yīng)的結(jié)點。

4.2 內(nèi)核態(tài)檢測文件描述符就緒狀態(tài)的方式

  • select:采用輪詢方式,線性掃描所有用戶關(guān)注的文件描述符,如果檢測到某個文件描述符已就緒,就修改用戶傳進來的數(shù)據(jù)結(jié)構(gòu)fd_set的值。
  • poll:同樣采用輪詢方式,線性掃描所有用戶關(guān)注的文件描述符,如果檢測到某個文件描述符就緒,內(nèi)核就修改文件描述符fd對應(yīng)的revents的值,并將其加入到內(nèi)核的等待隊列中。
  • epll:采用回調(diào)方式。在執(zhí)行epoll_ctl的ADD操作時,不僅將文件描述符放入紅黑樹上,并且還注冊了回調(diào)函數(shù),如果某個文件描述符已就緒,它會主動調(diào)用回調(diào)函數(shù),該回調(diào)函數(shù)將文件描述符放入到就緒鏈表中。

4.3 找到就緒文件描述符并傳遞給用戶態(tài)的方式

  • select:將之前傳入到內(nèi)核態(tài)的數(shù)據(jù)結(jié)構(gòu)(fd_set)重新拷貝傳出到用戶態(tài),并返回就緒的文件描述符數(shù)量。但是用戶程序并不知道哪些文件描述符是處于就緒態(tài),因此需要在用戶程序中對所有的文件描述符再一次進行遍歷來判斷。
  • poll:將之前傳入到內(nèi)核態(tài)的數(shù)據(jù)結(jié)構(gòu)(pollfd數(shù)組)重新拷貝傳出到用戶態(tài),并返回就緒的文件描述符數(shù)量。用戶程序同樣不知道哪些文件描述符是處于就緒態(tài),需要遍歷判斷。
  • epoll:epoll只需要檢測就緒事件鏈表中有無數(shù)據(jù)即可,如有,則只需將就緒鏈表的數(shù)據(jù)拷貝傳出到用戶態(tài),并返回就緒的文件描述符數(shù)量。由于返回的就是就緒態(tài)的文件描述符,因此用戶程序不需要通過遍歷來判斷,而是直接處理即可。

4.4 重復(fù)監(jiān)聽文件描述符的處理方式

  • select:將新的監(jiān)聽文件描述符集合拷貝傳入內(nèi)核中,繼續(xù)以上步驟。
  • poll:將新的struct pollfd結(jié)構(gòu)體數(shù)組拷貝傳入內(nèi)核中,繼續(xù)以上步驟。
  • epoll:無需重新構(gòu)建紅黑樹,直接沿用已存在的即可。

4.5 三種IO多路復(fù)用的適用場景

select、poll:適合在連接數(shù)少并且連接都十分活躍的情況下。

epoll:適用在連接數(shù)很多,活躍連接較少的情況下。

表面上看epoll的性能最好,但是在連接數(shù)少并且連接都十分活躍的情況下,select和poll的性能可能比epoll要好,畢竟epoll的通知機制需要調(diào)用很多的函數(shù)回調(diào),這也是一筆不小的系統(tǒng)開銷。
select、poll的低效是因為每次它們都需要輪詢。但低效也是相對的,視情況而定,也可通過良好的設(shè)計改善。

五、總結(jié)

  • select,poll,epoll都是IO多路復(fù)用的實現(xiàn)機制。它們本質(zhì)上還是同步IO,而不是異步IO,因為它們都需要在讀寫事件就緒后自己負責進行讀寫操作,而這個讀寫過程是阻塞的;而異步I/O則無需自己負責進行讀寫,異步I/O的實現(xiàn)會負責把數(shù)據(jù)從內(nèi)核空間拷貝到用戶空間。
  • select、poll的底層實現(xiàn)中需要自己不斷地輪詢所有fd集合,直到文件描述符就緒,期間可能要睡眠和喚醒多次交替。而epoll其實也需要調(diào)用 epoll_wait 不斷輪詢就緒鏈表,期間也可能多次睡眠和喚醒交替,但是它是當某個文件描述符就緒時,主動調(diào)用回調(diào)函數(shù),把就緒的文件描述符放入就緒鏈表中,并喚醒在epoll_wait中進入睡眠的進程。雖然都要睡眠和交替,但是select和poll在“醒著”的時候要遍歷整個fd集合,而epoll在“醒著”的 時候只須判斷一下就緒鏈表是否為空就行了,這就節(jié)省了大量的CPU時間,這就是回調(diào)機制帶來的性能提升。
  • select、poll每次調(diào)用(調(diào)用select()、poll()函數(shù))都要把所有文件描述符fd集合從用戶態(tài)拷貝到內(nèi)核態(tài),而epoll是在初始調(diào)用epoll_create時在內(nèi)核區(qū)先開辟好緩存區(qū),然后在調(diào)用epoll_ctl時,將待注冊的文件描述符從用戶態(tài)拷貝到內(nèi)核態(tài),并且只需要拷貝這一次,在每次調(diào)用epoll_wait時,不再需要重復(fù)拷貝,這就節(jié)省了內(nèi)存復(fù)制帶來的系統(tǒng)開銷。

為了便于閱讀,我們將這3組I/O多路復(fù)用的系統(tǒng)調(diào)用的區(qū)別總結(jié)成一個圖表,如下圖所示:

圖片

select、poll 和 epoll的區(qū)別

六、面試題

1、在epoll IO多路復(fù)用中,某個socket讀到一半,在這個socket上又有讀事件來了怎么辦?

答:為了避免在同一個socket上再次監(jiān)聽到同一個可讀事件,可以在對應(yīng)的描述符中添加 EPOLL_ONESHOT事件,其效果是監(jiān)聽到一次事件后就將對應(yīng)的描述符從監(jiān)聽集合中移除,也就不會再被追蹤到了。讀操作完成后再把對應(yīng)的文件描述符重新加入監(jiān)聽集合。

2、LT和ET模式下的阻塞與非阻塞?

答:在ET(水平觸發(fā))模式下,也是epoll的默認模式,epoll_wait返回可讀事件,表明socket一定收到了數(shù)據(jù),我們可以使用read函數(shù)來讀取數(shù)據(jù)。如果指定讀取的數(shù)據(jù)大于緩沖區(qū)數(shù)據(jù),無論socket是阻塞還是非阻塞,read函數(shù)不會阻塞,會返回實際讀取到的數(shù)據(jù)大小。在read之后再次調(diào)用read,如果socket是阻塞的,read將阻塞,直到接收到數(shù)據(jù)才返回。此時,如果指定讀取的數(shù)據(jù)小于緩沖區(qū)中數(shù)據(jù),epoll_wait 會繼續(xù)被觸發(fā),因為還有讀緩沖區(qū)中還有數(shù)據(jù)沒有被讀取完。

在ET(邊緣觸發(fā))模式下,只有新的數(shù)據(jù)到來時才會觸發(fā)。如果指定讀取的數(shù)據(jù)小于緩沖區(qū)中的數(shù)據(jù),epoll_wait 不會被繼續(xù)觸發(fā)。因此,使用ET模式時,有數(shù)據(jù)到來時,必須循環(huán)讀取讀緩沖區(qū)中的數(shù)據(jù),直到read返回-1,并且errno錯誤碼為EAGAIN,才算讀取完了全部緩沖區(qū)中的內(nèi)容。

  • 對于監(jiān)聽的listen_fd,最好使用LT模式,如果使用ET模式會導(dǎo)致高并發(fā)情況下,有的客戶端會連接不上。如果非要使用ET模式,可以在while循環(huán)中調(diào)用accept()函數(shù)。
  • 對于讀寫的conn_fd,LT模式下,阻塞和非阻塞效果都一樣,因為在阻塞模式下,如果數(shù)據(jù)讀取不完全則返回繼續(xù)觸發(fā),反之讀取完則返回繼續(xù)等待。建議將文件描述符設(shè)置為非阻塞。
  • 對于讀寫的conn_fd,ET模式下,必須使用非阻塞IO,并要求一次性地完整讀寫完全部數(shù)據(jù)。因為如果不一次性讀取完緩沖區(qū)中的全部數(shù)據(jù),緩沖區(qū)剩余數(shù)據(jù)不會被 epoll_wait 再次觸發(fā)。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • IO
    IO
    +關(guān)注

    關(guān)注

    0

    文章

    448

    瀏覽量

    39170
  • 參數(shù)
    +關(guān)注

    關(guān)注

    11

    文章

    1838

    瀏覽量

    32247
  • UDP
    UDP
    +關(guān)注

    關(guān)注

    0

    文章

    325

    瀏覽量

    33957
  • 編程接口
    +關(guān)注

    關(guān)注

    1

    文章

    38

    瀏覽量

    7994
收藏 人收藏

    評論

    相關(guān)推薦

    [6.4.1]--多路復(fù)用

    多路復(fù)用數(shù)字邏輯
    李開鴻
    發(fā)布于 :2022年11月13日 01:18:45

    一節(jié)課了解IO多路復(fù)用-2021.8.31-大海老師 - 第1節(jié) #硬聲創(chuàng)作季

    IO多路復(fù)用
    充八萬
    發(fā)布于 :2023年09月01日 21:27:46

    一節(jié)課了解IO多路復(fù)用-2021.8.31-大海老師 - 第7節(jié) #硬聲創(chuàng)作季

    IO多路復(fù)用
    充八萬
    發(fā)布于 :2023年09月01日 21:32:48

    一節(jié)課了解IO多路復(fù)用-2021.8.31-大海老師 - 第8節(jié) #硬聲創(chuàng)作季

    IO多路復(fù)用
    充八萬
    發(fā)布于 :2023年09月01日 21:33:38

    一節(jié)課了解IO多路復(fù)用-2021.8.31-大海老師 - 第9節(jié) #硬聲創(chuàng)作季

    IO多路復(fù)用
    充八萬
    發(fā)布于 :2023年09月01日 21:34:29

    一節(jié)課了解IO多路復(fù)用-2021.8.31-大海老師 - 第10節(jié) #硬聲創(chuàng)作季

    IO多路復(fù)用
    充八萬
    發(fā)布于 :2023年09月01日 21:35:19

    一節(jié)課了解IO多路復(fù)用-2021.8.31-大海老師 - 第13節(jié) #硬聲創(chuàng)作季

    IO多路復(fù)用
    充八萬
    發(fā)布于 :2023年09月01日 21:37:50

    多路復(fù)用技術(shù)

    2.3  多路復(fù)用技術(shù)2.3.1  頻分多路復(fù)用2.3.2  時分多路復(fù)用2.3.3  波分多路復(fù)用2.3.4  碼分
    發(fā)表于 06-27 21:46 ?0次下載

    多路復(fù)用多路復(fù)用總線轉(zhuǎn)換橋的設(shè)計與實現(xiàn)

    多路復(fù)用多路復(fù)用總線轉(zhuǎn)換橋的設(shè)計與實現(xiàn) 提出了一種新穎的非多路復(fù)用總線與多路復(fù)用總線的轉(zhuǎn)換接口電路。以兩種總線的典型代表芯片TMS
    發(fā)表于 03-28 15:14 ?958次閱讀
    非<b class='flag-5'>多路復(fù)用</b>與<b class='flag-5'>多路復(fù)用</b>總線轉(zhuǎn)換橋的設(shè)計與實現(xiàn)

    復(fù)用器的多路復(fù)用

    復(fù)用器的多路復(fù)用  多路復(fù)用
    發(fā)表于 01-07 14:27 ?1191次閱讀

    時分多路復(fù)用(TDM),時分多路復(fù)用(TDM)的原理是什么?

    時分多路復(fù)用(TDM),時分多路復(fù)用(TDM)的原理是什么?  為了提高信道利用率,使多個信號沿同一信道傳輸而互相不干擾,稱
    發(fā)表于 03-19 14:07 ?1w次閱讀

    時分多路復(fù)用(TDM),時分多路復(fù)用(TDM)是什么意思

    時分多路復(fù)用(TDM),時分多路復(fù)用(TDM)是什么意思 這種方法是把傳輸信道按時間來分割,為每個用戶指定一個時間間隔,每個間隔里傳輸信號
    發(fā)表于 04-03 15:28 ?5926次閱讀

    網(wǎng)絡(luò)IO的弊端以及多路復(fù)用IO的優(yōu)勢

    為了講多路復(fù)用,當然還是要跟風,采用鞭尸的思路,先講講傳統(tǒng)的網(wǎng)絡(luò) IO 的弊端,用拉踩的方式捧起多路復(fù)用 IO 的優(yōu)勢。 為了方便理解,以下所有代碼都是偽代碼,知道其表達的意思即可。
    的頭像 發(fā)表于 08-25 18:01 ?2937次閱讀
    網(wǎng)絡(luò)<b class='flag-5'>IO</b>的弊端以及<b class='flag-5'>多路復(fù)用</b><b class='flag-5'>IO</b>的優(yōu)勢

    掌握多片F(xiàn)PGA的多路復(fù)用

    多片F(xiàn)PGA之間的互連,經(jīng)常提到多路復(fù)用概念,也經(jīng)常提到TDM的概念
    發(fā)表于 06-06 10:07 ?420次閱讀
    掌握多片F(xiàn)PGA的<b class='flag-5'>多路復(fù)用</b>

    什么是io多路復(fù)用?IO多路復(fù)用的優(yōu)缺點

    IO多路復(fù)用是一種同步IO模型,它允許單個進程/線程同時處理多個IO請求。具體來說,一個進程/線程可以監(jiān)視多個文件句柄,一旦某個文件句柄就緒,就能夠通知應(yīng)用程序進行相應(yīng)的讀寫操作。在沒
    的頭像 發(fā)表于 01-18 15:48 ?1664次閱讀