Java基础知识强化之IO流笔记73:NIO之 Channel
2024-08-24 13:35:52
1. Java NIO的Channel(通道)类似 Stream(流),但又有些不同:
- 既可以从通道中读取数据,又可以写数据到通道。但流的读写通常是单向的。
- 通道可以异步地读写。
- 通道中的数据总是要先读到一个Buffer,或者总是要从一个Buffer中写入。
正如上面所说,从通道读取数据到缓冲区,从缓冲区写入数据到通道。如下图所示:
2. Channel的实现:
这些是Java NIO中最重要的通道的实现:
- FileChannel
- DatagramChannel
- SocketChannel
- ServerSocketChannel
FileChannel :从文件中读写数据。
DatagramChannel: 能通过UDP读写网络中的数据。
SocketChannel :能通过TCP读写网络中的数据。
ServerSocketChannel:可以监听新进来的TCP连接,像Web服务器那样。对每一个新进来的连接都会创建一个SocketChannel。
基本的 Channel 示例:
(1)下面是一个使用FileChannel读取数据到Buffer中的示例:
RandomAccessFile aFile = new RandomAccessFile("data/nio-data.txt", "rw");
FileChannel inChannel = aFile.getChannel(); ByteBuffer buf = ByteBuffer.allocate(48); int bytesRead = inChannel.read(buf);
while (bytesRead != -1) { System.out.println("Read " + bytesRead);
10 buf.flip(); while(buf.hasRemaining()){
System.out.print((char) buf.get());
} buf.clear();
bytesRead = inChannel.read(buf);
}
aFile.close();
注意 buf.flip() 的调用,首先读取数据到Buffer,然后反转Buffer,接着再从Buffer中读取数据。下一节会深入讲解Buffer的更多细节。
buf.flip():前面写入数据到Buffer的时候,指针到达了Buffer末尾,这里需要使用flip()反转一下,将缓存字节数组的指针设置为数组的开始序列即数组下标0。这样就可以从buffer开头,对该buffer进行遍历(读取)了。
最新文章
- java基础集合经典训练题
- 各大IT技术博客排行榜
- case when
- AIX碎碎念
- java.util.List接口的方法subList()的使用注意事项
- jquery选择器实例说明
- fine-uploader 5.11.8 (最新版) 使用感受
- Android Studio 错误 Duplicate files copied in APK META-INF/LICENSE.txt
- 读懂IL代码(三)
- C++单链表的创建与操作
- Mysql的执行顺序
- ODBC、OLE DB、 ADO、ODAC、ODP.NET
- CodeForces 681C Heap Operations(模拟)
- 从C#到TypeScript - Promise
- C语言的三目运算符
- Nginx geoip模块
- PageInfo 前台分页js,带分页栏
- 启动supervisord 生成openvpn用于android的证书
- 手把手教你搭建一个Elasticsearch集群
- kafka启动报错:另一个程序正在使用此文件,进程无法访问。
热门文章
- 一种将Region转为Polyline的方法
- CCF 201403-2	窗口 (STL模拟)
- ASP.NET MVC- UrlHelper的用法
- Http下的各种操作类.WebApi系列~通过HttpClient来调用Web Api接口
- 69道java Spring面试题和答案
- Java利用Math.random()方法随机生成A-Z的字符
- glibc strlen delphi pascal
- SAE J1850 VPW PWM, SAE J2411 SWC, ISO 11898 CAN, SAE J1708, Chrysler CCD 接口芯片电路
- C++ foreach
- Swift学习笔记十