分散读取与聚集写入
分散读取与聚集写入
分散读取(scattering Reads):将通道中的数据分散到多个缓冲区中

聚集写入(gathering Writes):将多个缓冲区的数据聚集到通道中

package com.toov5.Nio;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
public class BufferTest03 {
public static void main(String[] args) throws IOException {
//随机访问
RandomAccessFile raf = new RandomAccessFile("test.txt", "rw");
//拿到通道
FileChannel channel = raf.getChannel();
//分配制定大小缓冲区
ByteBuffer buffer1 = ByteBuffer.allocate(100);
ByteBuffer buffer2 = ByteBuffer.allocate(1024);
//分散读取
ByteBuffer[] buffers = {buffer1,buffer2};
//通道里面进行读取
channel.read(buffers);
//写入完毕之后 for 循环
for(ByteBuffer byteBuffer : buffers) {
//切换成读的模式
byteBuffer.flip();
}
System.out.println(new String(buffers[0].array(),0,buffers[0].limit()));
System.out.println("*****************************************");
System.out.println(new String(buffers[1].array(),1,buffers[1].limit()));
System.out.println(".....聚集读取.........");
RandomAccessFile randomAccessFile = new RandomAccessFile("test2.txt", "rw");
//获取通道
FileChannel channel2 = randomAccessFile.getChannel();
channel2.write(buffers);
randomAccessFile.close();
raf.close();
}
}


分散读取 聚集写入
分散读取与聚集写入
本文详细介绍了Java NIO中的分散读取和聚集写入技术。分散读取允许从通道将数据直接读入多个缓冲区,而聚集写入则可以将多个缓冲区的数据一次性写入通道。通过实例演示了如何使用这两个功能来提高I/O操作的效率。
523

被折叠的 条评论
为什么被折叠?



