Java NIO的通道類似流,但又有些不同:
正如上面所說(shuō),從通道讀取數(shù)據(jù)到緩沖區(qū),從緩沖區(qū)寫入數(shù)據(jù)到通道。如下圖所示:
Channel的實(shí)現(xiàn)
這些是Java NIO中最重要的通道的實(shí)現(xiàn):
基本的 Channel 示例
下面是一個(gè)使用FileChannel讀取數(shù)據(jù)到Buffer中的示例:
注意 buf.flip() 的調(diào)用,首先讀取數(shù)據(jù)到Buffer,然后反轉(zhuǎn)Buffer,接著再?gòu)腂uffer中讀取數(shù)據(jù)。下一節(jié)會(huì)深入講解Buffer的更多細(xì)節(jié)。
- 既可以從通道中讀取數(shù)據(jù),又可以寫數(shù)據(jù)到通道。但流的讀寫通常是單向的。
- 通道可以異步地讀寫。
- 通道中的數(shù)據(jù)總是要先讀到一個(gè)Buffer,或者總是要從一個(gè)Buffer中寫入。
正如上面所說(shuō),從通道讀取數(shù)據(jù)到緩沖區(qū),從緩沖區(qū)寫入數(shù)據(jù)到通道。如下圖所示:

Channel的實(shí)現(xiàn)
這些是Java NIO中最重要的通道的實(shí)現(xiàn):
- FileChannel 從文件中讀寫數(shù)據(jù)。
- DatagramChannel 能通過(guò)UDP讀寫網(wǎng)絡(luò)中的數(shù)據(jù)。
- SocketChannel 能通過(guò)TCP讀寫網(wǎng)絡(luò)中的數(shù)據(jù)。
- ServerSocketChannel可以監(jiān)聽(tīng)新進(jìn)來(lái)的TCP連接,像Web服務(wù)器那樣。對(duì)每一個(gè)新進(jìn)來(lái)的連接都會(huì)創(chuàng)建一個(gè)SocketChannel。
基本的 Channel 示例
下面是一個(gè)使用FileChannel讀取數(shù)據(jù)到Buffer中的示例:
RandomAccessFile aFile = new RandomAccessFile("c:/piaohailin.txt", "rw"); FileChannel inChannel = aFile.getChannel(); ByteBuffer buf = ByteBuffer.allocate(1024); while (inChannel.read(buf) != -1) { System.out.println("Read " + bytesRead); buf.flip(); while (buf.hasRemaining()) { System.out.print((char) buf.get()); } buf.clear(); } aFile.close();
注意 buf.flip() 的調(diào)用,首先讀取數(shù)據(jù)到Buffer,然后反轉(zhuǎn)Buffer,接著再?gòu)腂uffer中讀取數(shù)據(jù)。下一節(jié)會(huì)深入講解Buffer的更多細(xì)節(jié)。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
