JAVA NIO Scatter/Gather(矢量IO)

矢量IO=Scatter/Gather:

在多个缓冲区上实现一个简单的IO操作。减少或避免了缓冲区拷贝和系统调用(IO)

write:Gather

数据从几个缓冲区顺序抽取并沿着通道发送,就好比全部缓冲区全部连接起来放入一个大的缓冲区进行发送,缓冲区本身不具备gather能力。

read:Scatter

从通道读取的数据会按顺序散布到多个缓冲区,直到缓冲区被填满或者通道数据读完。

Gather:

Scatter:

示例代码:

 1 /**
 2      * channel Gather/Scatter
 3      */
 4     public static void channelGatherScatter(){
 5         ByteBuffer head = ByteBuffer.allocate(4);
 6         ByteBuffer body = ByteBuffer.allocate(100);
 7         RandomAccessFile afile = null;
 8         RandomAccessFile bfile = null;
 9         ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
10         try {
11             afile = new RandomAccessFile("hello.txt", "r");
12             bfile = new RandomAccessFile("hehe.txt", "rw");
13             readWriteLock.readLock().lock();
14             FileChannel fileChannel = afile.getChannel();
15             ByteBuffer[] buffers = {head, body};
16             while (fileChannel.read(buffers) != -1){
17             }
18             head.flip();
19             body.flip();
20             System.out.println(new String(head.array()));
21             System.out.println(new String(body.array()));
22             readWriteLock.readLock().unlock();
23             fileChannel.close();
24             afile.close();
25
26             readWriteLock.writeLock().lock();
27             FileChannel bfileChannel = bfile.getChannel();
28
29             while (bfileChannel.write(buffers) > 0){
30             }
31
32             readWriteLock.writeLock().unlock();
33             bfileChannel.close();
34             bfile.close();
35         }catch (Exception e){
36             e.printStackTrace();
37         }
38     }

带offset、length参数重载read write方法,指明从那个buffer开始,共使用多少个buffer。

时间: 2024-10-12 19:45:09

JAVA NIO Scatter/Gather(矢量IO)的相关文章

Java NIO Scatter/Gather

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

【JAVA】【NIO】5、Java NIO Scatter / Gather

标题手段Java NIO该分散体浓缩 Java NIO内置支持分散与收集.的概念主要用于信道分散聚集的读写. 读出的分散体的一个通道被读多个数据buffer在.因此.数据分散到多个buffer中. 对一个通道的集中写就是将数据从多个buffer中写到一个通道中.因此.通道从多个buffer将数据收集到一个通道中. 分散收集经经常使用于对数据传输分开处理的场景. 比方,一条消息由header和body构成,你须要将header和body保存在不同的buffer中. 这样做就是的对header和bo

Java NIO Scatter/Gather(4)

scatter/gather经常用于需要将传输的数据分开处理的场合. 分散(scatter)从Channel中读取是指在读操作时将读取的数据写入多个buffer中.因此,Channel将从Channel中读取的数据“分散(scatter)”到多个Buffer中. 聚集(gather)写入Channel是指在写操作时将多个buffer的数据写入同一个Channel,因此,Channel 将多个Buffer中的数据“聚集(gather)”后发送到Channel. Scattering ReadsSc

Java网络编程和NIO详解2:JAVA NIO一步步构建IO多路复用的请求模型

Java网络编程与NIO详解2:JAVA NIO一步步构建IO多路复用的请求模型 知识点 nio 下 I/O 阻塞与非阻塞实现 SocketChannel 介绍 I/O 多路复用的原理 事件选择器与 SocketChannel 的关系 事件监听类型 字节缓冲 ByteBuffer 数据结构 场景 接着上一篇中的站点访问问题,如果我们需要并发访问10个不同的网站,我们该如何处理? 在上一篇中,我们使用了java.net.socket类来实现了这样的需求,以一线程处理一连接的方式,并配以线程池的控制

Java nio 笔记:系统IO、缓冲区、流IO、socket通道

一.Java IO 和 系统 IO 不匹配 在大多数情况下,Java 应用程序并非真的受着 I/O 的束缚.操作系统并非不能快速传送数据,让 Java 有事可做:相反,是 JVM 自身在 I/O 方面效率欠佳.操作系统与 Java 基于流的 I/O模型有些不匹配.操作系统要移动的是大块数据(缓冲区),这往往是在硬件直接存储器存取(DMA)的协助下完成的.而 JVM 的 I/O 操作类喜欢操作小块数据--单个字节.几行文本.结果,操作系统送来整缓冲区的数据,java.io 包的流数据类再花大量时间

Java NIO vs. IO

Java Nio 1 Java NIO Tutorial 2 Java NIO Overview 3 Java NIO Channel 4 Java NIO Buffer 5 Java NIO Scatter / Gather 6 Java NIO Channel to Channel Transfers 7 Java NIO Selector 8 Java NIO FileChannel 9 Java NIO SocketChannel 10 Java NIO ServerSocketChan

Java NIO 完全学习笔记(转)

本篇博客依照 Java NIO Tutorial翻译,算是学习 Java NIO 的一个读书笔记.建议大家可以去阅读原文,相信你肯定会受益良多. 1. Java NIO Tutorial Java NIO,被称为新 IO(New IO),是 Java 1.4 引入的,用来替代 IO API的. Java NIO:Channels and Buffers 标准的 Java IO API ,你操作的对象是字节流(byte stream)或者字符流(character stream),而 NIO,你操

Java NIO DatagramChannel

Java Nio 1 Java NIO Tutorial 2 Java NIO Overview 3 Java NIO Channel 4 Java NIO Buffer 5 Java NIO Scatter / Gather 6 Java NIO Channel to Channel Transfers 7 Java NIO Selector 8 Java NIO FileChannel 9 Java NIO SocketChannel 10 Java NIO ServerSocketChan

Java NIO Tutorial

Java Nio 1 Java NIO Tutorial 2 Java NIO Overview 3 Java NIO Channel 4 Java NIO Buffer 5 Java NIO Scatter / Gather 6 Java NIO Channel to Channel Transfers 7 Java NIO Selector 8 Java NIO FileChannel 9 Java NIO SocketChannel 10 Java NIO ServerSocketChan