摘要:當?shù)臄?shù)據(jù)準備好時,就會接到通知,得到那些已經(jīng)準備好的數(shù)據(jù)。當與客戶端連接的數(shù)據(jù)沒有準備好時,會處于等待狀態(tài)不過幸好,用于管理的線程數(shù)是極少量的,而一旦有任何一個準備好了數(shù)據(jù),就能立即得到通知,獲取數(shù)據(jù)進行處理。
java NIO是NEW IO的簡稱,它是一種可以替代javaIO的一套新的IO機制。它提供了一套不同java標準IO的操作機制。嚴格來說,NIO與并發(fā)并無直接關系。但是,使用NIO可以大大提高線程的使用效率。 java NIO中涉及的基礎內(nèi)容有通道和緩沖區(qū)、文件IO和網(wǎng)絡IO。 對于標注的網(wǎng)絡IO來說,我們會使用socket進行網(wǎng)絡的讀寫。為了讓服務器可以支持更多的客戶端連接,通常的做法是為每個客戶端連接開啟一個線程。 要了解NIO,我們首先要知道在NIO中的一個關鍵組建Channel(通道)。Channel有點類似于流,一個Channel可以和文件或者網(wǎng)絡Socket對應,如果Channel對應著一個Socket,那么往這個Channel中寫數(shù)據(jù),就等同于向Socket中寫入數(shù)據(jù)。 另外一個與Channel密切相關的Selector,在Channel的眾多實現(xiàn)中,有一個SelectortableChannel實現(xiàn),表示可被選擇的通道。任何一個SelectableChannel都可以將自己注冊到一個Selector中,這樣,這個Channel就能被Selector所管理。而一個Selector可以管理多個SelectableChannel。當SelectableChannel的數(shù)據(jù)準備好時,Selector就會接到通知,得到那些已經(jīng)準備好的數(shù)據(jù)。而SocketChannel就是SelectableChannel的一種。 一個Selector可以由一個線程進行管理,而一個SocketChannel則可以表示一個客戶端連接,因此就構成由一個或者極少數(shù)線程,來處理大量客戶端連接的結構。當與客戶端連接的數(shù)據(jù)沒有準備好時,Selector會處于等待狀態(tài)(不過幸好,用于管理Selector的線程數(shù)是極少量的),而一旦有任何一個SocketChannel準備好了數(shù)據(jù),Selector就能立即得到通知,獲取數(shù)據(jù)進行處理。
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/74882.html
摘要:如果什么事都沒得做,它也不會死循環(huán),它會將線程休眠起來,直到下一個事件來了再繼續(xù)干活,這樣的一個線程稱之為線程。而請求處理邏輯既可以使用單獨的線程池進行處理,也可以跟放在讀寫線程一塊處理。 Netty到底是什么 從HTTP說起 有了Netty,你可以實現(xiàn)自己的HTTP服務器,F(xiàn)TP服務器,UDP服務器,RPC服務器,WebSocket服務器,Redis的Proxy服務器,MySQL的P...
摘要:緩沖區(qū)的限制不能為負,并且不能大于其容量。如果指向的位置超過限制,則拋出異常。使用臨時緩沖區(qū)執(zhí)行低層次操作。臨時緩沖區(qū)對象離開作用域,并最終成為被回收的無用數(shù)據(jù)。 前天剛好看了點《UNIX網(wǎng)絡編程》,比較頭大?,F(xiàn)在我來整理一下所學所得,并用于個人備忘。如果有不對,請批評。 想要解鎖更多新姿勢?請訪問https://blog.tengshe789.tech/ IO模型介紹 IO模型是什么...
摘要:緩沖區(qū)的限制不能為負,并且不能大于其容量。如果指向的位置超過限制,則拋出異常。使用臨時緩沖區(qū)執(zhí)行低層次操作。臨時緩沖區(qū)對象離開作用域,并最終成為被回收的無用數(shù)據(jù)。 前天剛好看了點《UNIX網(wǎng)絡編程》,比較頭大。現(xiàn)在我來整理一下所學所得,并用于個人備忘。如果有不對,請批評。 想要解鎖更多新姿勢?請訪問https://blog.tengshe789.tech/ IO模型介紹 IO模型是什么...
摘要:的產(chǎn)生原因是使的編程更容易。定義一個異步事件驅(qū)動的網(wǎng)絡應用框架,幫助快速開發(fā)高性能的客戶端與服務端。每一個一個客戶端請求注冊一個這個會處理這個請求的事件直到這個請求結束。 近日在學習netty,卻發(fā)現(xiàn)沒那么容易上手,專研了幾天后算是弄清楚了netty到底是干什么的,所看資料比較多,此文章便把這些資料與我的思考做一個總結幫助大家更好入門。 要更好理解netty首先要了解以下一些前置知識 ...
閱讀 2224·2019-08-30 15:54
閱讀 1960·2019-08-30 13:49
閱讀 679·2019-08-29 18:44
閱讀 834·2019-08-29 18:39
閱讀 1118·2019-08-29 15:40
閱讀 1538·2019-08-29 12:56
閱讀 3151·2019-08-26 11:39
閱讀 3104·2019-08-26 11:37