让星星⭐月亮告诉你,Java NIO之Buffer详解 属性capacity/position/limit/mark 方法put(X)/get()/flip()/compact()/clear()

简介: 这段代码演示了Java NIO中`ByteBuffer`的基本操作,包括分配、写入、翻转、读取、压缩和清空缓冲区。通过示例展示了`position`、`limit`和`mark`属性的变化过程,帮助理解缓冲区的工作原理。
package nio;

import java.nio.ByteBuffer;

public class BufferTest {
    public static void main(String[] args) throws InterruptedException {
        ByteBuffer buf = ByteBuffer.allocate(9);
        System.out.println("初始capacity = " +buf.capacity());
        System.out.println("初始position = " + buf.position());
        System.out.println("初始limit = " + buf.limit());
        System.out.println("初始mark = " + buf.mark());
        buf.put("123456789".getBytes());
        System.out.println("put写之后的position = " + buf.position());
        System.out.println("put写之后的limit = " + buf.limit());
        System.out.println("put写之后的mark = " + buf.mark());

        buf.flip();//put写之后要flip,将position置为0,将limit置为写入的最后一个元素(待操作的下一个元素)所在的索引位置
        System.out.println("flip之后的position = " + buf.position());
        System.out.println("flip之后的limit = " + buf.limit());
        System.out.println("flip之后的mark = " + buf.mark());

        /*
        while(buf.hasRemaining()){
            System.out.println("#" + (char)buf.get());
        }
        System.out.println("get之后的position = " + buf.position());
        System.out.println("get之后的limit = " + buf.limit());
        System.out.println("get之后的mark = " + buf.mark());
        */

        for(int i = 0 ; i <= 3; i++ ){
            System.out.println("#" + (char)buf.get());
        }
        System.out.println("部分get读之后的position = " + buf.position());

        buf.compact();
        System.out.println("compact之后的position = " + buf.position());
        System.out.println("compact之后的limit = " + buf.limit());
        System.out.println("compact之后的mark = " + buf.mark());

        buf.put("abcd".getBytes());
        buf.flip();
        while(buf.hasRemaining()){
            System.out.println("#" + (char)buf.get());
        }

        buf.clear();
        System.out.println("clear之后的position = " + buf.position());
        System.out.println("clear之后的limit = " + buf.limit());
        System.out.println("clear之后的mark = " + buf.mark());
    }
}
目录
相关文章
|
2月前
|
Java
让星星⭐月亮告诉你,自定义定时器和Java自带原生定时器
定时器是一种可以设置多个具有不同执行时间和间隔的任务的工具。本文介绍了定时器的基本概念、如何自定义实现一个定时器,以及Java原生定时器的使用方法,包括定义定时任务接口、实现任务、定义任务处理线程和使用Java的`Timer`与`TimerTask`类来管理和执行定时任务。
52 3
|
2月前
|
机器学习/深度学习 算法 搜索推荐
让星星⭐月亮告诉你,Java冒泡排序及其时间复杂度计算
冒泡排序是一种简单的排序算法,通过多次遍历数组,每次比较相邻元素并交换位置,将较小的元素逐步移至数组前端。第一轮结束后,最小值会位于首位;第二轮则将次小值置于第二位,依此类推。经过 (n-1) 轮遍历后,数组完成排序。冒泡排序的时间复杂度为 O(n²),在最优情况下(已排序数组)时间复杂度为 O(n)。示例代码展示了如何实现冒泡排序。
54 1
|
2月前
|
Java
让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)
本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。
27 1
|
2月前
|
Java
让星星⭐月亮告诉你,Java synchronized(*.class) synchronized 方法 synchronized(this)分析
本文通过Java代码示例,介绍了`synchronized`关键字在类和实例方法上的使用。总结了三种情况:1) 类级别的锁,多个实例对象在同一时刻只能有一个获取锁;2) 实例方法级别的锁,多个实例对象可以同时执行;3) 同一实例对象的多个线程,同一时刻只能有一个线程执行同步方法。
20 1
|
2月前
|
Java
让星星⭐月亮告诉你,Java异常分类[Throwable(Error/Exception(RuntimeException/其他异常)) 检查时异常 非检查时异常]
本文深入解析了Java异常处理机制,重点介绍了`Throwable`类及其子类`Error`和`Exception`,并通过实例代码、流程图和表格详细解释了异常的分类、区别及处理方法,帮助读者掌握异常处理的关键技巧,提升程序的稳定性和健壮性。
55 1
|
2月前
|
Java
Java 集合存在相同属性,其他元素累加
Java 集合存在相同属性,其他元素累加
33 0
|
2月前
|
小程序 Java
小程序通过get请求提交数据到java后台
小程序通过get请求提交数据到java后台
30 0
|
3月前
|
Java 编译器 测试技术
|
JSON Java 数据格式
JAVA获取GET和POST请求参数
JAVA获取GET和POST请求参数
2099 0
|
20天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####