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

    一、缓冲区(Buffer):在 Java NIO 中负责数据的存取。缓冲区就是数组。用于存储不同数据类型的数据
    根据数据类型不同(boolean 除外),提供了相应类型的缓冲区:
    ByteBuffer
    CharBuffer
    ShortBuffer
    IntBuffer
    LongBuffer
    FloatBuffer
    DoubleBuffer

    上述缓冲区的管理方式几乎一致,通过 allocate() 获取缓冲区

    二、缓冲区存取数据的两个核心方法:
    put() : 存入数据到缓冲区中
    get() : 获取缓冲区中的数据

    三、缓冲区中的四个核心属性:
    capacity : 容量,表示缓冲区中最大存储数据的容量。一旦声明不能改变。
    limit : 界限,表示缓冲区中可以操作数据的大小。(limit 后数据不能进行读写)
    position : 位置,表示缓冲区中正在操作数据的位置。

    mark : 标记,表示记录当前 position 的位置。可以通过 reset() 恢复到 mark 的位置

    0 <= mark <= position <= limit <= capacity

    四、直接缓冲区与非直接缓冲区:
    非直接缓冲区:通过 allocate() 方法分配缓冲区,将缓冲区建立在 JVM 的内存中
    直接缓冲区:通过 allocateDirect() 方法分配直接缓冲区,将缓冲区建立在物理内存中。可以提高效率

  • 相关阅读:
    yum 下载安装包以及依赖包
    《将博客搬至CSDN》
    Lucene
    Solr
    LVS原理详解(3种工作模式及8种调度算法)
    正向代理与反向代理
    网关,网卡
    NAT地址转换
    Nginx学习总结
    网络_OSI模型_数据包传输
  • 原文地址:https://www.cnblogs.com/keleaiww/p/10969950.html
Copyright © 2011-2022 走看看