JAVA-2NIO之Channel
注意:轉(zhuǎn)載自并發(fā)編程網(wǎng) – ifeve.com本文鏈接地址:?Java NIO系列教程(二) Channel
Channel
Java NIO的通道類似流,但又有些不同:
- 既可以從通道中讀取數(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
- DatagramChannel
- SocketChannel
- ServerSocketChannel
FileChannel 從文件中讀寫數(shù)據(jù)。
DatagramChannel 能通過(guò)UDP讀寫網(wǎng)絡(luò)中的數(shù)據(jù)。
SocketChannel 能通過(guò)TCP讀寫網(wǎng)絡(luò)中的數(shù)據(jù)。
ServerSocketChannel可以監(jiān)聽新進(jìn)來(lái)的TCP連接,像Web服務(wù)器那樣。對(duì)每一個(gè)新進(jìn)來(lái)的連接都會(huì)創(chuàng)建一個(gè)SocketChannel。
二、基本的 Channel 示例
下面是一個(gè)使用FileChannel讀取數(shù)據(jù)到Buffer中的示例:
public class Channel1 {public static void main(String[] args) {try {RandomAccessFile raf = new RandomAccessFile("./.gitignore","rw");FileChannel channel = raf.getChannel(); //獲取通道ByteBuffer bf = ByteBuffer.allocate(50); //通過(guò)靜態(tài)allocate方法創(chuàng)建一個(gè)緩沖區(qū),容量為50byte[] bytes = new byte[]{};bytes = "123".getBytes();bf = ByteBuffer.wrap(bytes); //通過(guò)靜態(tài)wrap方法,byte數(shù)組生成緩沖區(qū),緩沖區(qū)中保留了原數(shù)據(jù)while(bf.hasRemaining()){System.out.print((char) bf.get());}int bytesRead ;while ((bytesRead = channel.read(bf)) != -1) { //將通道中的數(shù)據(jù)寫入緩沖區(qū),并判斷通道中的數(shù)據(jù)是否到末尾System.out.println("Read " + bytesRead);bf.flip(); //反轉(zhuǎn)緩沖區(qū) 實(shí)際上就是將position置為0 后續(xù)buffer詳細(xì)介紹while(bf.hasRemaining()){ //判斷緩沖區(qū)中是否還有值System.out.print((char) bf.get()); //輸出緩沖區(qū)中的值 }bf.clear(); //清理緩沖區(qū) }raf.close(); //關(guān)閉RandomAccessFile} catch (IOException e) {e.printStackTrace();}} }注意 buf.flip() 的調(diào)用,首先讀取數(shù)據(jù)到Buffer,然后反轉(zhuǎn)Buffer,接著再?gòu)腂uffer中讀取數(shù)據(jù)。下一節(jié)會(huì)深入講解Buffer的更多細(xì)節(jié)
轉(zhuǎn)載于:https://www.cnblogs.com/zhangxinly/p/6958570.html
總結(jié)
以上是生活随笔為你收集整理的JAVA-2NIO之Channel的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: s5_day2作业
- 下一篇: 【Oracle】Exadata虚拟机配置