Java NIO 之 ByteBuffer 测试用例

分享一下,关于ByteBuffer的一些非常基础的测试用例

package xingej.buffer.test001;

import java.nio.ByteBuffer;
//注意:1、原生JAVA NIO的ByteBuffer的缓冲区是不能添加字符串的,其实,从名字也可以看出来,是Byte + Buffer =>ByteBuffer
//也就是说,ByteBuffer是针对字节的缓存区
public class ByteBufferTest {

    public static void main(String[] args) {
        //分配8个字节的缓冲区
        ByteBuffer buffer = ByteBuffer.allocate(8);
        //打印出初始状态下position, limit, capacity的值
        System.out.println("---->position:\t" + buffer.position() + "\n---->limit:\t" + buffer.limit() + "\n---->capacity:\t" + buffer.capacity());

        //-------------------------------测试-----put----操作---------------------------------------------------------------
        System.out.println("-----put---操作---前----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());
        //往缓冲区里,添加一个字符“h”,再查看position, limit, capacity的值
        buffer.put("h".getBytes());
        System.out.println("-----put---操作---后----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());

        //-------------------------------测试-----flip----操作---------------------------------------------------------------
        System.out.println("\n-----flip---操作---前----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());
        buffer.flip();
        System.out.println("-----flip---操作---后----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());

        //-------------------------------测试-----get----操作---------------------------------------------------------------
        System.out.println("\n-----get---操作---前----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());
        System.out.println("-----从缓存里取数据------:\t" + buffer.get());
        System.out.println("-----get---操作---后----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());

        //-------------------------------测试-----limit----操作---------------------------------------------------------------
        //重新设定缓存可以存储的容量大小是1个字节,
        //很明显,如果实际存储的字节大小,超过1个字节的话,就会抛异常的
        System.out.println("\n-----limit---操作---前----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());
        buffer.limit(1);
        try{
            //因为,缓存里已经存储里h 1个字节,因此,ell是不会存储到缓存里的,而且会抛异常的
            buffer.put("ell".getBytes());
        } catch (Exception e) {
//            e.printStackTrace();
        }
        System.out.println("-----limit---操作---后----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());

        //-------------------------------测试-----clear----操作---------------------------------------------------------------
        System.out.println("\n-----clear---操作---前----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());
        buffer.clear();
        System.out.println("-----clear---操作---后----------->position:\t" + buffer.position() + "  ---->limit:\t" + buffer.limit() + "  ---->capacity:\t" + buffer.capacity());
    }

}

总结:

put操作、get操作 改变的是position的值

buffer的不足之处,就是,读或者写之前,一般需要调用flip()方法。

测试用例已经上传到git上

https://github.com/xej520/xingej-nio

时间: 2024-07-31 06:34:17

Java NIO 之 ByteBuffer 测试用例的相关文章

Java NIO 之 ByteBuffer

抽象类ByteBuffer ByteBuffer的继承关系 父类 子类 目前,大概有5个实现类 ByteBuffer 底层,主要依赖? 顾名思义,从ByteBuffer的名称来看,这个缓冲区针对的是字节类型的缓冲区, 从源码中,也可以查询到, 就是字节数组 ByteBuffer的主要api 我这里仅仅分享一下,get,put,因为这两个方法用到的最多了. put 操作 目前有5个实现类,我们可以依次查看,到底如何实现的 DirectByteBuffer.java DirectByteBuffer

java nio通过ByteBuffer输出文件信息

1.通过ByteBuffer的get()方法每次读取一个字节转换成char类型输出. fc = new FileInputStream("src/demo20/data.txt").getChannel(); ByteBuffer buff = ByteBuffer.allocate(BSIZE); buff = ByteBuffer.allocateDirect(BSIZE); fc.read(buff); buff.flip(); while (buff.hasRemaining(

IO的详细解释:It's all about buffers: zero-copy, mmap and Java NIO

There are use cases where data need to be read from source to a sink without modification. In code this might look quite simple: for example in Java, you may read data from one InputStream chunk by chunk into a small buffer (typically 8KB), and feed

java.nio.ByteBuffer中flip,rewind,clear方法的区别

对缓冲区的读写操作首先要知道缓冲区的下限.上限和当前位置.下面这些变量的值对Buffer类中的某些操作有着至关重要的作用: limit:所有对Buffer读写操作都会以limit变量的值作为上限. position:代表对缓冲区进行读写时,当前游标的位置. capacity:代表缓冲区的最大容量(一般新建一个缓冲区的时候,limit的值和capacity的值默认是相等的). flip.rewind.clear这三个方法便是用来设置这些值的. clear方法 public final Buffer

JAVA NIO 内存泄露

写NIO程序经常使用ByteBuffer来读取或者写入数据,那么使用ByteBuffer.allocate(capability)还是使用ByteBuffer.allocteDirect(capability)来分配缓存了?第一种方式是分配JVM堆内存,属于GC管辖范围,由于需要拷贝所以速度相对较慢:第二种方式是分配OS本地内存,不属于GC管辖范围,由于不需要内存拷贝所以速度相对较快. 我们肯定想选择比较快的,但问题是直接内存不属于GC管辖范围,需要弄清楚这部分内存如何管理,否则造成内存泄露就麻

Java NIO 之 Selector 练习

目的:本编文章主要想分享一下NIO方面的知识,由于最近几天工作不忙,趁机学习了下Java NIO Selector的相关知识:主要是实践操作的:具体的理论知识,可以参考网上的文章. 测试用例主要有三种方式: 其实,是服务器端的逻辑不变,客户端有三种方式而已. 服务器端:2个selector + channel, 客户端:一个channel 服务器端:2个selector + channel, 客户端:多个channel(多线程方式) 服务器端:2个selector + channel, 客户端:

Java NIO中的缓冲区Buffer(一)缓冲区基础

什么是缓冲区(Buffer) 定义 简单地说就是一块存储区域,哈哈哈,可能太简单了,或者可以换种说法,从代码的角度来讲(可以查看JDK中Buffer.ByteBuffer.DoubleBuffer等的源码),Buffer类内部其实就是一个基本数据类型的数组,以及对这个缓冲数组的各种操作: 常见的缓冲区如ByteBuffer.IntBuffer.DoubleBuffer...内部对应的数组依次是byte.int.double... 与通道的关系 在Java NIO中,缓冲区主要是跟通道(Chann

java nio

NIO 是java nonblocking(非阻塞) IO 的简称,在jdk1.4 里提供的新api .Sun 官方标榜的特性如下: 为所有的原始类型提供(Buffer)缓存支持.字符集编码解码解决方案. Channel :一个新的原始I/O 抽象. 支持锁和内存映射文件的文件访问接口. 提供多路(non-bloking) 非阻塞式的高伸缩性网络I/O . Java NIO非堵塞应用通常适用用在I/O读写等方面,我们知道,系统运行的性能瓶颈通常在I/O读写,包括对端口和文件的操作上,之前,在打开

JAVA NIO 内存映射(转载)

原文地址:http://blog.csdn.net/fcbayernmunchen/article/details/8635427 Java类库中的NIO包相对于IO 包来说有一个新功能是内存映射文件,日常编程中并不是经常用到,但是在处理大文件时是比较理想的提高效率的手段.本文我主要想结合操作系统中(OS)相关方面的知识介绍一下原理. 在传统的文件IO操作中,我们都是调用操作系统提供的底层标准IO系统调用函数 read().write() ,此时调用此函数的进程(在JAVA中即java进程)由当