ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

9.NIO 核心1:缓冲区(Buffer)

2022-08-16 20:32:02  阅读:159  来源: 互联网

标签:NIO Buffer System buffer limit 缓冲区 println out


static xxxBuffer allocate(int capacity):创建一个容量为capacity 的xxxBuffer对象

 

 

样例:
     @Test
    public void test01() {
        //1.分配一个缓冲区,容量设置为10
        ByteBuffer buffer = ByteBuffer.allocate(10);
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//0
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//10
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        System.out.println("=================================");

        //2.往缓冲区中放数据
        String name = "wumengda";
        buffer.put(name.getBytes());
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//8
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//10
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        System.out.println("=================================");

        //3.Buffer flip() 将缓冲区的界限设置为当前位置,并将当前位置设置为0:可读模式
        buffer.flip();
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//0
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//8
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10


        //4.get数据获取
        char ch= (char) buffer.get();
        System.out.println(ch);//w
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//1
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//8
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
    }
样例2:clear的使用
  @Test
    public void test02() {
        ByteBuffer buffer = ByteBuffer.allocate(10);
        String name = "wumengda";
        buffer.put(name.getBytes());
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//8
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//10
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        System.out.println("=================================");

        buffer.flip();
        byte[] b = new byte[2];
        buffer.get(b);
        System.out.println(new String(b));//wu
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//2
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//8
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        System.out.println("=================================");

        //重点1:clear 清空缓冲区,发现并不是真的清空,是将position置为0,limit和capacity置为最大,此时如果再放值,会进行覆盖
        buffer.clear();
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//0
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//10
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        char ch = (char) buffer.get();
        System.out.println(ch);//w
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//1
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//10
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10

    }

 

样例3:mark和resert的使用(标记和重置) 
@Test
    public void test02() {
        ByteBuffer buffer = ByteBuffer.allocate(10);
        String name = "wumengda";
        buffer.put(name.getBytes());
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//8
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//10
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        System.out.println("=================================");

        buffer.flip();
        byte[] b = new byte[2];
        buffer.get(b);
        System.out.println(new String(b));//wu
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//2
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//8
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        System.out.println("=================================");

        //重点:标记当前位置,后面可以resert
        buffer.mark();
        byte[] by = new byte[3];
        buffer.get(by);
        System.out.println(new String(by));//men
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//5
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//8
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
        System.out.println("=================================");
        buffer.reset();
        if (buffer.hasRemaining()){
            System.out.println("buffer剩余:"+buffer.remaining());//6
        }
        //返回当缓冲区的当前位置
        System.out.println(buffer.position());//2
        //返回缓冲区的limit界限位置
        System.out.println(buffer.limit());//8
        //返回缓冲区的容量
        System.out.println(buffer.capacity());//10
    }

直接内存的使用场景:

  1.有很大的数据需要存储,他的生命周期又很长

  2.适合频繁操作的io操作,比如网络并发场景

   @Test
    public void test3(){
        ByteBuffer buffer=ByteBuffer.allocate(1024);
        //判断是不是直接内存
        System.out.println(buffer.isDirect());//false
        //创建直接内存
        ByteBuffer byteBuffer=ByteBuffer.allocateDirect(1024);
        System.out.println(byteBuffer.isDirect());//true
    }

 

标签:NIO,Buffer,System,buffer,limit,缓冲区,println,out
来源: https://www.cnblogs.com/wmd-l/p/16592864.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有