A Selector
是一個(gè)Java NIO組件,可以檢查一個(gè)或多個(gè)NIO通道,并確定哪些通道已準(zhǔn)備就緒,例如讀取或?qū)懭搿_@樣一個(gè)線程可以管理多個(gè)通道,從而管理多個(gè)網(wǎng)絡(luò)連接。
為什么選擇器?
使用單個(gè)線程來(lái)處理多個(gè)通道的優(yōu)點(diǎn)是您需要較少的線程來(lái)處理通道。你可以使用一個(gè)線程來(lái)處理你所有的頻道。線程之間的切換消耗系統(tǒng)資源較大,每個(gè)線程也占用操作系統(tǒng)中的一些資源(內(nèi)存)。所以你使用的線程越少越好。
現(xiàn)代操作系統(tǒng)和CPU在多任務(wù)處理中變得越來(lái)越好,所以隨著時(shí)間的推移,多線程的開(kāi)銷越來(lái)越小。事實(shí)上,如果CPU具有多個(gè)內(nèi)核,處理少量任務(wù)時(shí)會(huì)浪費(fèi)CPU電源。
這是一個(gè)線程使用Selector
來(lái)管理3個(gè)通道的流程圖:
Java NIO:A Thread uses a Selector to handle 3 Channel's |