Java NIO系列教程(四) Scatter/Gather

原文地址:http://tutorials.jenkov.com/java-nio/scatter-gather.html

作者:Jakob Jenkov   译者:郭蕾   

Java NIO开始支持scatter/gather,scatter/gather用于描述从Channel(译者注:Channel在中文经常翻译为通道)中读取或者写入到Channel的操作。
分散(scatter)从Channel中读取是指在读操作时将读取的数据写入多个buffer中。因此,Channel将从Channel中读取的数据“分散(scatter)”到多个Buffer中。
聚集(gather)写入Channel是指在写操作时将多个buffer的数据写入同一个Channel,因此,Channel 将多个Buffer中的数据“聚集(gather)”后发送到Channel。

scatter / gather经常用于需要将传输的数据分开处理的场合,例如传输一个由消息头和消息体组成的消息,你可能会将消息体和消息头分散到不同的buffer中,这样你可以方便的处理消息头和消息体。

Scattering Reads
Scattering Reads是指数据从一个channel读取到多个buffer中。如下图描述:

Java NIO: Scattering Read

Java NIO: Scattering Read

代码示例如下:

[code lang=”java”]
ByteBuffer header = ByteBuffer.allocate(128);
ByteBuffer body = ByteBuffer.allocate(1024);

ByteBuffer[] bufferArray = { header, body };

channel.read(bufferArray);
[/code]

注意buffer首先被插入到数组,然后再将数组作为channel.read() 的输入参数。read()方法按照buffer在数组中的顺序将从channel中读取的数据写入到buffer,当一个buffer被写满后,channel紧接着向另一个buffer中写。

Scattering Reads在移动下一个buffer前,必须填满当前的buffer,这也意味着它不适用于动态消息(译者注:消息大小不固定)。换句话说,如果存在消息头和消息体,消息头必须完成填充(例如 128byte),Scattering Reads才能正常工作。

Gathering Writes

Gathering Writes是指数据从多个buffer写入到同一个channel。如下图描述:

Java NIO: Gathering Write

Java NIO: Gathering Write

代码示例如下:

[code lang=”java”]
ByteBuffer header = ByteBuffer.allocate(128);
ByteBuffer body = ByteBuffer.allocate(1024);

//write data into buffers

ByteBuffer[] bufferArray = { header, body };

channel.write(bufferArray);
[/code]

buffers数组是write()方法的入参,write()方法会按照buffer在数组中的顺序,将数据写入到channel,注意只有position和limit之间的数据才会被写入。因此,如果一个buffer的容量为128byte,但是仅仅包含58byte的数据,那么这58byte的数据将被写入到channel中。因此与Scattering Reads相反,Gathering Writes能较好的处理动态消息。

原创文章,转载请注明: 转载自并发编程网 – ifeve.com本文链接地址: Java NIO系列教程(四) Scatter/Gather

  • Trackback 关闭
  • 评论 (10)
    • andy
    • 2014/05/26 9:39下午

    good job! thanks.

    • 匿名
    • 2014/10/13 5:33下午

    初步看懂了 感谢!

    • miniWolfer
    • 2014/11/05 4:21下午

    初学,体会不到有啥用。呵呵

    • wussrc
    • 2015/03/30 10:56上午

    基本算是看懂了,但是还不知道什么地方会用到,应该怎么用。感谢

    • liuc
    • 2015/05/15 9:25下午

    mark ,感谢

    • lee_mingzhu
    • 2016/04/22 7:01下午

    一样,看懂了文章,却没有看到使用场景,感觉在封装底层协议时也许用的上,自己的应用中不知道什么时候会用到这样的操作。

    • 18576762572@139.com
    • 2018/08/03 4:10下午

    我是看Tomcat内核书籍 发现里面用了很多NIO的内容,才来学习的。

    • wangqingzh
    • 2019/10/07 9:59下午

    mark

    • 路过的
    • 2022/02/04 3:45下午

    文中: Java NIO开始支持scatter/gather,scatter/gather用于描述从Channel(译者注:Channel在中文经常翻译为通道)中读取或者写入到Channel的操作

    应该是 读取或写入到Buffer中的操作吧? 不是从Channel读取或写入到Channel中

      • 路过的
      • 2022/02/04 3:47下午

      了解了, 没事了, 语句理解错了…

return top