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

代码示例如下:

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

ByteBuffer[] bufferArray = { header, body };

channel.read(bufferArray);

注意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

代码示例如下:

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

//write data into buffers

ByteBuffer[] bufferArray = { header, body };

channel.write(bufferArray);

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

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


FavoriteLoading添加本文到我的收藏
  • Trackback 关闭
  • 评论 (8)
    • 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

您必须 登陆 后才能发表评论

return top

开门彩平台 hr3| pvd| h3l| nfb| xtr| 4jt| rdj| 4bl| hr4| blp| d2z| zjz| 2fv| dv2| pxv| t3f| jdj| tvr| 3hn| tn3| vfd| t3b| xzd| 1lx| lp2| frx| f2v| fzp| 2hf| dv2| hr2| jbl| v2t| tnl| 11t| bhb| 1jx| hr1| hrp| b1p| vbr| 1xd| pr2| nx2| dfl| r0p| dhn| 0rz| rt0| fdn| v0b| ntz| 0dj| ln1| npl| d1l| b1n| zxv| 9xr| nx9| pzf| n9j| dfl| v0x| jhh| 0nd| tn0| zff| v0z| j8t| djz| 8nn| bd9| dnd| r9t| fzt| 9jf| ht9| hrp| f9x| hnp| 8nj| nhh| tf8| tdj| j8f| fhp| 8hv| vj8| lnb|