IO多路復(fù)用是指內(nèi)核一旦發(fā)現(xiàn)進程指定的一個或者多個IO條件準(zhǔn)備讀取,它就通知該進程
通俗理解(摘自網(wǎng)上一大神)
這些名詞比較繞口,理解涵義就好。一個epoll場景:一個酒吧服務(wù)員(一個線程),前面趴了一群醉漢,突然一個吼一聲“倒酒”(事件),你小跑過去給他倒一杯,然后隨他去吧,突然又一個要倒酒,你又過去倒上,就這樣一個服務(wù)員服務(wù)好多人,有時沒人喝酒,服務(wù)員處于空閑狀態(tài),可以干點別的玩玩手機。至于epoll與select,poll的區(qū)別在于后兩者的場景中醉漢不說話,你要挨個問要不要酒,沒時間玩手機了。io多路復(fù)用大概就是指這幾個醉漢共用一個服務(wù)員。
三個函數(shù)
1、select
進程指定內(nèi)核監(jiān)聽哪些文件描述符(最多監(jiān)聽1024個fd)的哪些事件,當(dāng)沒有文件描述符事件發(fā)生時,進程被阻塞;當(dāng)一個或者多個文件描述符事件發(fā)生時,進程被喚醒。
當(dāng)我們調(diào)用select()時:
1 上下文切換轉(zhuǎn)換為內(nèi)核態(tài)
2 將fd從用戶空間復(fù)制到內(nèi)核空間
3 內(nèi)核遍歷所有fd,查看其對應(yīng)事件是否發(fā)生
4 如果沒發(fā)生,將進程阻塞,當(dāng)設(shè)備驅(qū)動產(chǎn)生中斷或者timeout時間后,將進程喚醒,再次進行遍歷
5 返回遍歷后的fd