linux epoll 學習

來源:互聯網
上載者:User

標籤:

一、epoll介紹

epoll是linux核心為處理大批量控制代碼而作的改進的poll,是linux下IO多工select、poll的增強版,它能顯著減少程式在大量並發串連中只有少量活躍的情況下的系統CPU利用率。

epoll有兩種工作方式:LT(水平觸發)、ET(邊緣觸發)

LT(level triggered,水平觸發)是預設的工作方式,並且同時支援block和non-block socket,在這種方式中,核心告訴你一個檔案描述符是否就緒了,然後你可以對這個就緒的fd進行IO操作。如果你不作任何操作,核心還是會繼續通知你的,所以,這種模式編程出錯的可能性要小一點。傳統的select/poll都是這種模型的代表。

ET(edge-triggered,邊緣觸發)是高速工作方式,只支援non-block socket。

linux epoll 學習

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.