在jdk1.4中提出的技術,非阻塞IO,采用的是基于事件處理方式。
傳統的io技術為阻塞的,比如讀一個文件,惹read方法是阻塞的,直到有數據讀入。
歸納為:
1、java io為阻塞,在打開一個io通道后,read將一直等待在端口一邊讀取字節內容,如果沒有內容進來,read相當于阻塞掉了。
2、在1的基礎上改進為,開設線程,serversocker.accept()后讓線程去等待,但是當并發量高的時候,相當耗費資源的。
3、java nio為非阻塞,采用的是reactor反應堆模式,或者說observer觀察者模式,監察io端口,注冊事件到selector,當事件滿足條件后觸發行為。
大致流程為:
java nio提供一個selector,這個類似一個觀察者,將需要探知的socketchannel注冊到selector上
接著我們做別的事情,當有事件發生時候,selector會通知我們,傳回一組selectionKey,我們讀取這些key就會獲得到我們剛剛注冊過的socketchannel,然后從這個channel讀取數據、處理業務邏輯。
selector內部原理,采用輪詢的方式,對所注冊的channel進行遍歷,判斷channel所注冊的事件是否發生。
代碼舉例為:
新聞熱點
疑難解答