前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ByteBuffer中的flip()、clear()、compact()

ByteBuffer中的flip()、clear()、compact()

作者头像
有一只柴犬
发布2024-01-25 11:22:45
1280
发布2024-01-25 11:22:45
举报
文章被收录于专栏:JAVA体系JAVA体系

NIO读取文件流的简单demo:

代码语言:javascript
复制
public static void main(String[] args) {
        try (FileChannel channel = new FileInputStream("data.txt").getChannel()){

            // 定义缓冲区 allocate分配大小
            ByteBuffer buffer = ByteBuffer.allocate(10);
            while(true) {
                // 去读缓冲区内容
                int read = channel.read(buffer);
                if(read != -1){
                    // 切换为读模式
                    buffer.flip();
                    while (buffer.hasRemaining()) {
                        System.out.println((char)buffer.get());
                    }
                    // 切换为写模式
//                    buffer.clear();
                    buffer.compact();
                } else {
                    break;
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

在读取文件流时,正确姿势为:

  • 向buffer写数据,如channel.read(buffer),此时默认为写模式
  • 调用flip()切换为读模式
  • 从buffer读取数据,如buffer.get()
  • 调用clear()或compact()切换为写模式
  • 重复以上步骤

为什么需要频繁切换读写模式呢?这里简单介绍一下flip(),clear(),compact()三者到底做了什么事。

1、ByteBuffer的内部结构

首先介绍三个属性:

代码语言:javascript
复制
capacity:bytebuffer容量大小
position:位移指针位置
limit:指针位移限制

ByteBuffer buffer = ByteBuffer.allocate(10)分配得到的初始空间大小为:

capacity:10字节

position:0

limit:为capacity的位置

当有数据写入时候,每写入一个字节,position往后移动一个字节位置,直到limit位置,该缓冲区满。

2、flip()方法

 如需要读取缓冲区数据,使用flip()切换为读数据模式,此时position和limit指针位置发生变化。

 position移动到最开始位置,limit移动到数据长度的末尾。每读取一个字节,position向后移动一个字节位置。直到limit位置处停止。

3、clear()方法

调用clear()方法,position和limit指针位置发生变化。

clear默认清空缓冲区,回到最开始分配的样子,即position=0,limit=capacity。

4、compact()方法

compact也可以切换为写模式,不过是把未读完成的数据向前压缩,然后再切换。

 如果缓冲区中数据没有读取完,就需要立马写入数据,所以需要对未读取完的数据进行压缩,避免数据丢失。compact也会改变position和limit指针位置,但position != 0,而是等于上次读取的位置,limit=capacity位置。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-01-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档