摘要:之后推出的是,是面向緩沖區(qū)的,數(shù)據(jù)讀取到一個它稍后處理的緩沖區(qū),需要時可在緩沖區(qū)中前后移動。之后的又引入了,對應(yīng)的可以實現(xiàn)模式。該接口常被用于高效的網(wǎng)絡(luò)文件的數(shù)據(jù)傳輸和大文件拷貝。進(jìn)階五模型從到和模式
Linux I/O model
blocking I/O
non blocking I/O
I/O multiplexing (select and poll)
signal driven I/O (SIGIO)
asynchronous I/O (the POSIX aio_ functions)
Chapter 6. I/O Multiplexing: The select and poll FunctionsJAVA實現(xiàn)
JAVA最早實現(xiàn)是IO是blocking I/O,是面向流的,每次從流中讀一個或多個字節(jié),直至讀取所有字節(jié),沒有被緩存在任何地方,且它不能前后移動流中的數(shù)據(jù)。之后推出的NIO是non blocking I/O,是面向緩沖區(qū)的,數(shù)據(jù)讀取到一個它稍后處理的緩沖區(qū),需要時可在緩沖區(qū)中前后移動。同時,借助于Selectors,它還可以實現(xiàn)I/O multiplexing,即reactor模式。之后的NIO 2.0又引入了asynchronous I/O,對應(yīng)的可以實現(xiàn)Proactor模式。
zero copyJava NIO中提供的FileChannel擁有transferTo和transferFrom兩個方法,可直接把FileChannel中的數(shù)據(jù)拷貝到另外一個Channel,或者直接把另外一個Channel中的數(shù)據(jù)拷貝到FileChannel。該接口常被用于高效的網(wǎng)絡(luò)/文件的數(shù)據(jù)傳輸和大文件拷貝。在操作系統(tǒng)支持的情況下,通過該方法傳輸數(shù)據(jù)并不需要將源數(shù)據(jù)從內(nèi)核態(tài)拷貝到用戶態(tài),再從用戶態(tài)拷貝到目標(biāo)通道的內(nèi)核態(tài),同時也避免了兩次用戶態(tài)和內(nèi)核態(tài)間的上下文切換,也即使用了“零拷貝”,所以其性能一般高于Java IO中提供的方法。
Java進(jìn)階(五)Java I/O模型從BIO到NIO和Reactor模式
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/77879.html
摘要:阻塞請求結(jié)果返回之前,當(dāng)前線程被掛起。也就是說在異步中,不會對用戶線程產(chǎn)生任何阻塞。當(dāng)前線程在拿到此次請求結(jié)果的過程中,可以做其它事情。事實上,可以只用一個線程處理所有的通道。 準(zhǔn)備知識 同步、異步、阻塞、非阻塞 同步和異步說的是服務(wù)端消息的通知機(jī)制,阻塞和非阻塞說的是客戶端線程的狀態(tài)。已客戶端一次網(wǎng)絡(luò)請求為例做簡單說明: 同步同步是指一次請求沒有得到結(jié)果之前就不返回。 異步請求不會...
摘要:一個多路復(fù)用器可以負(fù)責(zé)成千上萬的通道,沒有上限。不需要通過對多路復(fù)用器對注冊的通道進(jìn)行輪詢操作即可實現(xiàn)異步讀寫,從而簡化編程模型。同時,支持支持如果是怎么辦最后,到目前位置,支持不支持二無法擴(kuò)展作為的核心,無法擴(kuò)展,私有構(gòu)造函數(shù)。 前言 netty 學(xué)習(xí) 基于 netty in action 5th, 官網(wǎng)資料,網(wǎng)絡(luò)博客等 1.1 Why Netty? netty 是一個中間層的抽象 ...
摘要:而我們現(xiàn)在都已經(jīng)發(fā)布了,的都不知道,這有點說不過去了。而對一個的讀寫也會有響應(yīng)的描述符,稱為文件描述符,描述符就是一個數(shù)字,指向內(nèi)核中的一個結(jié)構(gòu)體文件路徑,數(shù)據(jù)區(qū)等一些屬性。 前言 只有光頭才能變強(qiáng) 回顧前面: 給女朋友講解什么是代理模式 包裝模式就是這么簡單啦 本來我預(yù)想是先來回顧一下傳統(tǒng)的IO模式的,將傳統(tǒng)的IO模式的相關(guān)類理清楚(因為IO的類很多)。 但是,發(fā)現(xiàn)在整理的過程已...
摘要:三同步非阻塞式以塊的方式處理數(shù)據(jù)面向緩存區(qū)的采用多路復(fù)用模式基于事件驅(qū)動是實現(xiàn)了的一個流行框架,的。阿里云分布式文件系統(tǒng)里用的就是。四異步非阻塞式基于事件驅(qū)動,不需要多路復(fù)用器對注冊通道進(jìn)行輪詢,采用設(shè)計模式。 一、什么是IO IO 輸入、輸出 (read write accept)IO是面向流的 二、BIO BIO是同步阻塞式IO 服務(wù)端與客戶端進(jìn)行三次握手后一個鏈路建立一個線程面...
摘要:三同步非阻塞式以塊的方式處理數(shù)據(jù)面向緩存區(qū)的采用多路復(fù)用模式基于事件驅(qū)動是實現(xiàn)了的一個流行框架,的。阿里云分布式文件系統(tǒng)里用的就是。四異步非阻塞式基于事件驅(qū)動,不需要多路復(fù)用器對注冊通道進(jìn)行輪詢,采用設(shè)計模式。 一、什么是IO IO 輸入、輸出 (read write accept)IO是面向流的 二、BIO BIO是同步阻塞式IO 服務(wù)端與客戶端進(jìn)行三次握手后一個鏈路建立一個線程面...
閱讀 2825·2021-11-18 10:02
閱讀 3689·2021-11-15 17:59
閱讀 2315·2021-09-06 15:00
閱讀 3353·2019-08-29 16:58
閱讀 1067·2019-08-26 10:34
閱讀 1587·2019-08-26 10:15
閱讀 1295·2019-08-26 10:11
閱讀 2728·2019-08-23 18:33