Java NIO系列教程(二) Channel
发布日期:2021-07-01 01:39:58
浏览次数:2
分类:技术文章
本文共 1025 字,大约阅读时间需要 3 分钟。
转载自
作者:Jakob Jenkov 译者:airu 校对:丁一
Java NIO的通道类似流,但又有些不同:
- 既可以从通道中读取数据,又可以写数据到通道。但流的读写通常是单向的。
- 通道可以异步地读写。
- 通道中的数据总是要先读到一个Buffer,或者总是要从一个Buffer中写入。
正如上面所说,从通道读取数据到缓冲区,从缓冲区写入数据到通道。如下图所示:
Channel的实现
这些是Java NIO中最重要的通道的实现:
- FileChannel
- DatagramChannel
- SocketChannel
- ServerSocketChannel
FileChannel 从文件中读写数据。
DatagramChannel 能通过UDP读写网络中的数据。
SocketChannel 能通过TCP读写网络中的数据。
ServerSocketChannel可以监听新进来的TCP连接,像Web服务器那样。对每一个新进来的连接都会创建一个SocketChannel。
基本的 Channel 示例
下面是一个使用FileChannel读取数据到Buffer中的示例:
01 | RandomAccessFile aFile = new RandomAccessFile( "data/nio-data.txt" , "rw" ); |
02 | FileChannel inChannel = aFile.getChannel(); |
03 |
04 | ByteBuffer buf = ByteBuffer.allocate( 48 ); |
05 |
06 | int bytesRead = inChannel.read(buf); |
07 | while (bytesRead != - 1 ) { |
08 |
09 | System.out.println( "Read " + bytesRead); |
10 | buf.flip(); |
11 |
12 | while (buf.hasRemaining()){ |
13 | System.out.print(( char ) buf.get()); |
14 | } |
15 |
16 | buf.clear(); |
17 | bytesRead = inChannel.read(buf); |
18 | } |
19 | aFile.close(); |
注意 buf.flip() 的调用,首先读取数据到Buffer,然后反转Buffer,接着再从Buffer中读取数据。下一节会深入讲解Buffer的更多细节。
转载地址:https://maokun.blog.csdn.net/article/details/80630688 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
表示我来过!
[***.240.166.169]2024年04月19日 10时15分31秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
location区段
2019-04-30
nginx访问控制、基于用户认证、https配置
2019-04-30
linux内存的寻址方式
2019-04-30
how2heap-double free
2019-04-30
how2heap-fastbin_dup_consolidate
2019-04-30
tf keras SimpleRNN源码解析
2019-04-30
MyBatisPlus简单入门(SpringBoot)
2019-04-30
攻防世界web进阶区web2详解
2019-04-30
xss-labs详解(上)1-10
2019-04-30
xss-labs详解(下)11-20
2019-04-30
攻防世界web进阶区ics-04详解
2019-04-30
sql注入总结学习
2019-04-30
Python实现决策树 Desision Tree & 可视化
2019-04-30
MATLAB与CUDA
2019-04-30
Linux png转jpg (convert命令)
2019-04-30
Ubuntu更新后终端中字体的颜色全是白色
2019-04-30
vscode git
2019-04-30
基于MATLAB的二进制数字调制与解调信号的仿真——2PSK
2019-04-30