zoukankan      html  css  js  c++  java
  • IntBuffer类的基本用法

    package com.ietree.basicskill.socket.basic.nio;
    
    import java.nio.IntBuffer;
    
    /**
     * Created by Administrator on 2017/5/25.
     */
    public class BufferTest {
        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
             buf.flip();
             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[] arr = new int[]{1,2,5};
             IntBuffer buf1 = IntBuffer.wrap(arr);
             System.out.println(buf1);
    
             IntBuffer buf2 = IntBuffer.wrap(arr, 0 , 2);
             //这样使用表示容量为数组arr的长度,但是可操作的元素只有实际进入缓存区的元素长度
             System.out.println(buf2);*/
    
             // 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();
             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) + ",");
             }
    
        }
    }
  • 相关阅读:
    Android vector标签 PathData 画图超详解
    Echarts 出现不明竖线解决方案
    关于华为手机Log.d打印不出来log的问题
    Java源码解读(一)——HashMap
    算法小题
    Python简单小程序练习
    TCP/IP协议栈(三)——linux 向下的报文处理
    TCP协议(二)——TIME_WAIT状态
    Linux文件系统inode、block解释权限(三)
    Linux 基本权限(一)
  • 原文地址:https://www.cnblogs.com/Dylansuns/p/6906486.html
Copyright © 2011-2022 走看看