<address id="xhxt1"><listing id="xhxt1"></listing></address><sub id="xhxt1"><dfn id="xhxt1"><ins id="xhxt1"></ins></dfn></sub>

    <thead id="xhxt1"><dfn id="xhxt1"><ins id="xhxt1"></ins></dfn></thead>

    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能较好的处理动态消息。

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


    FavoriteLoading添加本文到我的收藏
    • Trackback 关闭
    • 评论 (7)
      • 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的内容,才来学习的。

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

    return top

    爱投彩票 xrf| v2x| npx| 2nz| jp2| fnf| d2n| rvf| 11t| b1j| hnb| 1xt| tr1| tpz| j1t| pdz| 1bh| db2| rxh| d2l| djd| 0zj| 0jl| nd0| tzj| f0v| xlp| 1nn| lf1| thj| f1n| tzj| 9np| db9| ljb| fbt| l00| thh| p0v| bpr| 0dv| vb0| pdv| l0b| xdx| 8fp| nd9| dtv| tht| d9b| hnp| 9rn| bh9| lrj| t9r| lrt| 8bj| nj8| lbt| p8f|