Java NIO学习笔记(三)Channel

概述:

Channel(通道)在前面也提到过,是NIO的三大组件之一,相当于BIO中的流,不一样的是,通道是双向的、可异步的、读写必须经过缓冲区的。二流是单向、同步的。

Channel的一些实现:

FileChannel(读写文件)
DatagramChannel(UDP)
SocketChannel(TCP客户端)
ServerSocketChannel(TCP服务器端)

Scatter 分散:

将通道中的数据分散的写入到Buffer中。


12350543-5501a8a8832f313c.png
Scatter 分散

举个栗子:
消息头、消息体。

ByteBuffer header = ByteBuffer.allocate(128);
ByteBuffer body   = ByteBuffer.allocate(1024);

ByteBuffer[] bufferArray = { header, body };

channel.read(bufferArray);

这会将数据按顺序写入,但是不适合传输动态消息(因为大小不固定)

Gather 聚合:

将多个Buffer读取到一个通道中。


12350543-7d6667fcd81174e0.png
Gather 聚合

举个栗子:

ByteBuffer header = ByteBuffer.allocate(128);
ByteBuffer body   = ByteBuffer.allocate(1024);

ByteBuffer[] bufferArray = { header, body };

channel.write(bufferArray);

Gather可以传输动态的消息。

如果两个通道中有一个是FileChannel就可以直接从一个通道传输到另一个通道
通过transferFrom()、transferTo()方法、但是SocketChannel只能传输此刻已经准备好的数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值