복수의 캐시에 하나 개의 채널에서 분산 :( 판독 데이터)
분산 데이터 (데이터 채널 버퍼를 채우기 순차 버퍼로부터 판독하기 위해) 상기 버퍼로부터 판독 채널
채널에 :( 기록 버퍼들로부터 데이터를 집계)
은 "집합"버퍼 데이터가 복수의 채널에 기록 될
import org.junit.jupiter.api.Test;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
public class ChannelTest {
@Test
public void channel4() throws IOException {
RandomAccessFile raf1=new RandomAccessFile("文件路径","文件模式rw");
//1,获取通道
FileChannel channel1=raf1.getChannel();
//2,分配指定大小的缓冲区
ByteBuffer byteBuffer1=ByteBuffer.allocate(100);
ByteBuffer byteBuffer2=ByteBuffer.allocate(1024);
//3,分散读取
ByteBuffer[]buffers={byteBuffer1,byteBuffer2};
channel1.read(buffers);
for (ByteBuffer bf:buffers){
bf.flip();
}
//4,聚集写入
RandomAccessFile raf2=new RandomAccessFile("目标文件路径","模式rw");
FileChannel channel2 = raf2.getChannel();
channel2.write(buffers);
//5,关闭通道
channel1.close();
channel2.close();
}
}