zoukankan      html  css  js  c++  java
  • NIO buffer 缓冲区 API

    package bhz.nio.test;

    import java.nio.IntBuffer;

    public class TestBuffer {

    public static void main(String[] args) {

    // 1 基本操作

    //创建指定长度的缓冲区

    IntBuffer buf = IntBuffer.allocate(10);

    buf.put(13);// position位置:0 - > 1

    buf.put(21);// position位置:1 - > 2

    buf.put(35);// position位置:2 - > 3

    //把位置复位为0,也就是position位置:3 - > 0

    System.out.println(buf);

    buf.flip();//复位的时候会把 position赋值给limit,然后把0复制给position,可以看源码

    System.out.println("使用flip复位:" + buf);

    System.out.println("容量为: " + buf.capacity()); //容量一旦初始化后不允许改变(warp方法包裹数组除外)

    System.out.println("限制为: " + buf.limit()); //由于只装载了三个元素,所以可读取或者操作的元素为3 则limit=3

    System.out.println("获取下标为1的元素:" + buf.get(1));

    System.out.println("get(index)方法,position位置不改变:" + buf);

    buf.put(1, 4);

    System.out.println("put(index, change)方法,position位置不变:" + buf);;

    for (int i = 0; i < buf.limit(); i++) {

    //调用get方法会使其缓冲区位置(position)向后递增一位

    System.out.print(buf.get() + " ");

    }

    System.out.println("buf对象遍历之后为: " + buf);

    // 2 wrap方法使用

    // wrap方法会包裹一个数组: 一般这种用法不会先初始化缓存对象的长度,因为没有意义,最后还会被wrap所包裹的数组覆盖掉。

    // 并且wrap方法修改缓冲区对象的时候,数组本身也会跟着发生变化。

    int[] arrInt = new int[]{1,2,5};

    IntBuffer newBuf1 = IntBuffer.wrap(arrInt);

    System.out.println(newBuf1);//结果 :1,2,5 [pos=0 lim=3 cap=3]

    IntBuffer buf2 = IntBuffer.wrap(arrInt, 0 , 2);

    //这样使用表示容量为数组arr的长度,但是可操作的元素只有实际进入缓存区的元素长度

    System.out.println(buf2);//结果 :1,2 [pos=0 lim=2 cap=3]

    // 3 其他方法

    IntBuffer buf1 = IntBuffer.allocate(10);

    int[] arr = new int[]{1,2,5};

    buf1.put(arr);

    System.out.println(buf1);

    //一种复制方法

    IntBuffer buf3 = buf1.duplicate();

    System.out.println(buf3);

    //设置buf1的位置属性

    //buf1.position(0);

    buf1.flip(); //复位的时候会把 position赋值给limit,然后把0复制给position,可以看源码

    System.out.println(buf1);

    System.out.println("可读数据为:" + buf1.remaining());

    int[] arr2 = new int[buf1.remaining()];

    //将缓冲区数据放入arr2数组中去

    buf1.get(arr2);

    for(int i : arr2){

    System.out.print(Integer.toString(i) + ",");

    }

    }

     

    控制台输出:

    java.nio.HeapIntBuffer[pos=3 lim=10 cap=10]
    使用flip复位:java.nio.HeapIntBuffer[pos=0 lim=3 cap=10]
    容量为: 10
    限制为: 3
    获取下标为1的元素:21
    get(index)方法,position位置不改变:java.nio.HeapIntBuffer[pos=0 lim=3 cap=10]
    put(index, change)方法,position位置不变:java.nio.HeapIntBuffer[pos=0 lim=3 cap=10]
    13 4 35 buf对象遍历之后为: java.nio.HeapIntBuffer[pos=3 lim=3 cap=10]
    java.nio.HeapIntBuffer[pos=0 lim=3 cap=3]
    java.nio.HeapIntBuffer[pos=0 lim=2 cap=3]
    java.nio.HeapIntBuffer[pos=3 lim=10 cap=10]
    java.nio.HeapIntBuffer[pos=3 lim=10 cap=10]
    java.nio.HeapIntBuffer[pos=0 lim=3 cap=10]
    可读数据为:3
    1,2,5,

    }

  • 相关阅读:
    C#多线程之基础篇3
    C#多线程之基础篇2
    C#多线程之基础篇1
    Log4net入门(帮助类篇)
    Log4net入门(WCF篇)
    Log4net入门(ASP.NET MVC 5篇)
    Log4net入门(SQL篇)
    深入理解java:4.3. 框架编程之MyBatis原理深入解析
    深入理解java:4.2. 框架编程之Spring框架的设计理念
    深入理解java:4.1. 框架编程之Spring MVC
  • 原文地址:https://www.cnblogs.com/smallFishs/p/8094934.html
Copyright © 2011-2022 走看看