NIO——分散(Scatter)和聚集(Gather)+编码

本文详细介绍了Java NIO中的分散读取和聚集写入概念,通过示例展示了如何使用ByteBuffer数组从Channel进行分散读取,并将数据聚集写入到另一个Channel。同时,讲解了管道数据传输方法transferFrom和transferTo的用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

分散读取(Scattering Reads)

  • 是指从 Channel 中读取的数据“分散”到多个 Buffer
  • 注意:按照缓冲区的顺序,从 Channel 中读取的数据依次将 Buffer 填满

聚集写入(Gathering Writes)

  • 是指将多个 Buffer 中的数据“聚集”到 Channel。
  • 注意:按照缓冲区的顺序,写入 position 和 limit 之间的数据到 Channel
@Test
public void test1(){
    RandomAccessFile raf1 = null;
    RandomAccessFile raf2 = null;
    try {
        raf1 = new RandomAccessFile("1.txt","rw");
        //        获取通道
        Channel channel1= raf1.getChannel();
//            指定缓冲区
        ByteBuffer bf1 = ByteBuffer.allocate(100);
        ByteBuffer bf2 = ByteBuffer.allocate(1024);
        ByteBuffer[] bfs = {bf1,bf2};
       ((FileChannel) channel1).read(bfs);
       for(ByteBuffer buffer : bfs){
           buffer.flip();
       }
//       输出内容
        System.out.println(new String(bfs[0].array(),0,bfs[0].limit()));
        System.out.println(new String(bfs[1].array(),0,bfs[1].limit()));
//            聚集写入
        raf2 = new RandomAccessFile("2.txt","rw");
        FileChannel channel = raf2.getChannel();
        channel.write(bfs);
        channel.close();
        channel1.close();
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    }catch (IOException e){
    }
}

管道数据传输

方法说明
transferFrom()将数据从源通道传输到其他 Channel 中:
transferTo()将数据从源通道传输到其他 Channel 中:
public void test5() {
    try {
        FileChannel inChannel = FileChannel.open(Paths.get( "a.png"), StandardOpenOption.READ);
        FileChannel outChannel = FileChannel.open(Paths.get("3.png"), StandardOpenOption.WRITE, StandardOpenOption.READ,StandardOpenOption.CREATE);
//       重。。开始 大小 为 。。 到 。。
//       到哪里去
//       inChannel.transferTo(0,inChannel.size(),outChannel);
//       从哪里来
        outChannel.transferFrom(outChannel,0,inChannel.size());
        inChannel.close();
        outChannel.close();
    }catch (IOException e){
    }
}

FileChannel 的常用方法

方法说明
int read(ByteBuffer dst)从 Channel 中读取数据到 ByteBuffer
long read(ByteBuffer[] dsts)将 Channel 中的数据“分散”到 ByteBuffer[]
int write(ByteBuffer src)将 ByteBuffer 中的数据写入到 Channel
long write(ByteBuffer[] srcs)将 ByteBuffer[] 中的数据“聚集”到 Channel
long position()返回此通道的文件位置
FileChannel position(long p)设置此通道的文件位置
long size()返回此通道的文件的当前大小
FileChannel truncate(long s)将此通道的文件截取为给定大小
void force(boolean metaData)强制将所有对此通道的文件更新写入到存储设备中

字符集 : 编码 与 解码 Charset类

public void test2() throws CharacterCodingException {
        Charset gbk = Charset.forName("GBK");
//        过去编码器
        CharsetEncoder ce = gbk.newEncoder();
//        获取解码器
        CharsetDecoder cd = gbk.newDecoder();
        CharBuffer charBuffer = CharBuffer.allocate(102);
        charBuffer.put("你好");
        charBuffer.flip();
//	编码
        ByteBuffer byteBuffer = ce.encode(charBuffer);
        for(int i =0; i < byteBuffer.limit(); i ++){
            System.out.print(byteBuffer.get());
        }
        byteBuffer.flip();
  //	解码
        CharBuffer charBuffer1 = cd.decode(byteBuffer);
        System.out.println(charBuffer1.toString());
        System.out.println("-----------------");
        Charset utf = Charset.forName("utf-8");
        CharBuffer decode = utf.decode(byteBuffer);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值