Java NIO学习
概述
NIO是一種基于緩存的、非阻塞的異步IO。NIO主要涉及到三個(gè)概念:Buffer(緩存),Channel(通道),Selector(選擇器)。NIO和傳統(tǒng)IO不同在于:NIO是基于緩存的,而傳統(tǒng)IO是基于流的,傳統(tǒng)IO的數(shù)據(jù)是從一個(gè)出發(fā)地流向一個(gè)目的地,而NIO的數(shù)據(jù)是從一個(gè)Buffer通過Channel流向另一個(gè)Buffer的。這樣,線程就可以將IO過程交給Channel去管理,自己可以做其它是,所以NIO也是異步的,非阻塞的,而傳統(tǒng)IO在IO過程中必須等待,是同步的,阻塞的。NIO通過Selector可以監(jiān)聽多個(gè)Buffer的事件,并響應(yīng)事件對(duì)IO結(jié)果進(jìn)行處理,這樣,就可以用一個(gè)線程實(shí)現(xiàn)監(jiān)聽多個(gè)通道,對(duì)于單核處理器來說,這會(huì)提高性能??偟膩碚f,就是:
(1)NIO是異步的,非阻塞的
(2)NIO是基于緩存的
(3)NIO即可讀又可寫,是雙向的。
(4)NIO提供selector,可以用單線程實(shí)現(xiàn)多個(gè)通道的監(jiān)聽
Channel
通道用來操作Buffer,通過通道,可以寫入數(shù)據(jù)到Buffer,或者從緩存讀取數(shù)據(jù)。
打開通道
RandomAccessFile file = new RandomAccessFile("d://sample.txt","rw");FileChannel fileChannel = file.getChannel();這里打開的是一個(gè)FileChannel,當(dāng)然還有其他類型的通道,參看:Java NIO Channel
Buffer
Buffer是緩存,是一個(gè)內(nèi)存區(qū)塊,可供channel寫入或讀取。
創(chuàng)建Buffer
ByteBuffer buffer = ByteBuffer.allocate(48);切換工作模式
Buffer有兩種工作模式“讀取”和“寫入”,讀取之前,要調(diào)用filp()切換到讀取模式:
//切換到讀取模式 buffer.flip();//讀取數(shù)據(jù) while(buffer.hasRemaining()){char word =(char)buffer1.get(); }同樣,寫入之前調(diào)用clear()方法,清空buffer數(shù)據(jù),準(zhǔn)備寫入:
buffer.clear();fileChannel.read(buffer );Seletor
用來監(jiān)聽多個(gè)通道,沒用過感觸不深,還是看參考文檔靠譜!
參考文檔:http://tutorials.jenkov.com/ ,非常不錯(cuò)的網(wǎng)站
總結(jié)
以上是生活随笔為你收集整理的Java NIO学习的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: javascript --- repe
- 下一篇: java中的sql语句书写_Java中s