A Selector是一個Java NIO組件,可以檢查一個或多個NIO通道,并確定哪些通道已準(zhǔn)備就緒,例如讀取或?qū)懭?。這樣一個線程可以管理多個通道,從而管理多個網(wǎng)絡(luò)連接。

為什么選擇器?

  使用單個線程來處理多個通道的優(yōu)點(diǎn)是您需要較少的線程來處理通道。你可以使用一個線程來處理你所有的頻道。線程之間的切換消耗系統(tǒng)資源較大,每個線程也占用操作系統(tǒng)中的一些資源(內(nèi)存)。所以你使用的線程越少越好。

  現(xiàn)代操作系統(tǒng)和CPU在多任務(wù)處理中變得越來越好,所以隨著時間的推移,多線程的開銷越來越小。事實上,如果CPU具有多個內(nèi)核,處理少量任務(wù)時會浪費(fèi)CPU電源。

  這是一個線程使用Selector來管理3個通道的流程圖:

Java NIO:A Thread uses a Selector to handle 3 Channel's

創(chuàng)建選擇器

網(wǎng)友評論