NIO入门之缓冲区Buffer
缓存区 Buffer 是数据容器

- ByteBuffer 可以存储除了 boolean 以外的其他 7 种Java基本数据类型,如 getInt、putInt
- Buffer 是抽象类,它有除了 Boolean 以外的其他 7 种Java基本数据类型子类,如
IntBuffer
缓存区的初始化
⑴ 静态方法 allocate:初始化一个指定容量的缓存区

解释一下图例:
1.数组下标:数字(1,2,3,4,5)表示数组下标
1.数组:灰色长方形内表示真实有效的数组。
2.数组元素:数字所在的白色黑边正方形表示数组元素,可以通过例如 array[0] 来获取数组元素。但是注意,图中没有明确指定数组元素的值是什么。
3.虚拟下标:其中-1和6是虚拟的下标位置,如果使用这2个下标取值( array[-1] 或者 array[6] )会抛出 IndexOutOfBoundsException
⑵ 静态方法 wrap:把一个数组初始化成一个缓存区
- 如果是只把数组
array作为 wrap 的参数,那么效果和 allocate 类似。但是,修改数组中的值,等同于修改缓存区的值。 - 如果除了数组引用
array外,还有offset和length来指定子数组的开始位置和子数组的大小。效果如下图:

- 灰色的部分就是数组参数
array - 虚线框的部分表示从数组中划出的 子数组
缓存区存储数据

put()填充一个新的元素到数组中- 当前位置右移(position++)
缓冲区获取数据

get()获取当前位置的元素- 当前位置右移(position++)
核心操作
flip 操作
由写模式 转换为> 读模式

- limit = position,限制转到原先的 position 位置
- position = 0,游标归零
- mark = -1,标记清空
注意:
虽然,flip 的中文含义是 “翻动”,但是连续调用 flip 不能实现 写模式 -> 读模式 -> 写模式!
连续调用 flip 之后,postion == limit == 0。
因此,继续调用 get() 会抛出 读取超限 BufferUnderflowException ,调用 put() 会抛出 写入超限 BufferOverflowException
clear 操作
重新回到初始化状态,重新进入写模式

- limit = capacity,限制回归到容器容量
- position = 0,游标归零
- mark = -1,标记清空
注意
clear 实际并不会清理数据,而是调整 limit、position、mark 指向的位置
mark 操作

- mark = position,记录下当前位置
使用场景
替换一段内容:添加标记,以便后续调用 reset() 将 position 回到标记。
reset 操作

- position = mark,当前位置回到标记位置
注意

mark < 0抛出无效标记异常。说明必须要先 mark() 才能调用 reset()
rewind 操作

- position = 0,当前位置归零
- mark = -1,清除标记位置
剩余空间与超限异常
剩余空间
\]
其中,
\]
remaining 表示剩余空间大小。hasRemaining() 用来查询是否还有剩余空间。
读取超限

- 在
get读取数据时,如果position >= limit,抛出 BufferUnderflowException 异常
写入超限

- 在
put写入数据时,如果position >= limit,抛出 BufferOverflowException 异常
注意
如果是使用 wrap 初始化的缓冲区,即使没有到达容器容量 capacity,也会报错,因为此时 limit < capacity

总结:
- Buffer缓冲区是数据容器,可以用于读 get() 也可以用于写 put()。
- flip() 可以从写模式切换到读模式
- clear() 可以回到初始化状态
- mark() 和 reset() 需要配合使用,主要用于 替换某段内容
- 无论是读取超限还是写入超限,条件都是
position >= limit。即 如果进行接下来的读或者写操作,当前位置都将超过限制。
NIO入门之缓冲区Buffer的更多相关文章
- Java NIO中的缓冲区Buffer(一)缓冲区基础
什么是缓冲区(Buffer) 定义 简单地说就是一块存储区域,哈哈哈,可能太简单了,或者可以换种说法,从代码的角度来讲(可以查看JDK中Buffer.ByteBuffer.DoubleBuffer等的 ...
- Java NIO中的缓冲区Buffer(二)创建/复制缓冲区
创建缓冲区的方式 主要有以下两种方式创建缓冲区: 1.调用allocate方法 2.调用wrap方法 我们将以charBuffer为例,阐述各个方法的含义: allocate方法创建缓冲区 调用all ...
- 详解 缓冲区(Buffer 抽象类)
在本篇博文中,本人主要讲解NIO 的两个核心点 -- 缓冲区(Buffer) 和 通道 (Channel)之一的 缓冲区(Buffer), 有关NIO流的其他知识点请观看本人博文<详解 NIO流 ...
- Java NIO入门(二):缓冲区内部细节
Java NIO 入门(二)缓冲区内部细节 概述 本文将介绍 NIO 中两个重要的缓冲区组件:状态变量和访问方法 (accessor). 状态变量是前一文中提到的"内部统计机制"的 ...
- NIO(一)——缓冲区Buffer
NIO(一)--Buffer NIO简介 NIO即New IO,是用来代替标准IO的,提供了与标准IO完全不同传输方式. 核心: ...
- Java NIO -- 缓冲区(Buffer)的数据存取
缓冲区(Buffer): 一个用于特定基本数据类型的容器.由 java.nio 包定义的,所有缓冲区都是 Buffer 抽象类的子类.Java NIO 中的 Buffer 主要用于与 NIO 通道进行 ...
- NIO之缓冲区(Buffer)的数据存取
缓冲区(Buffer) 一个用于特定基本数据类行的容器.有java.nio包定义的,所有缓冲区都是抽象类Buffer的子类. Java NIO中的Buffer主要用于与NIO通道进行交互,数据是从通道 ...
- JAVA NIO缓冲区(Buffer)------ByteBuffer常用方法
参考:https://blog.csdn.net/xialong_927/article/details/81044759 缓冲区(Buffer)就是在内存中预留指定大小的存储空间用来对输入/输出(I ...
- Java NIO 缓冲区 Buffer
缓冲区 Buffer 是 Java NIO 中一个核心概念,它是一个线性结构,容量有限,存放原始类型数据(boolean 除外)的容器. 1. Buffer 中可以存放的数据类型 java.nio.B ...
随机推荐
- 下订单更新订单表然后减少库存表中的数据,出现库存超卖,使用数据库和redis坚决库存超卖的问题
上面的代码更新库存的数据,存在多线程的问题,第一种方法使用synchronized关键字修饰的语句块代码,但是性能较低,并且还是存在问题的 在分布式的场景下,当前库存系统部署在多个tomcat上,即使 ...
- ThinkPHP 5接阿里云短信接口
1.首先将api_sdk文件放入vendor文件夹下 2.在config文件中作相应的配置 3.封装发送短信的方法 4.调用发送短信方法
- 关于 urlencode 的使用和 json 模块的介绍
先附上一段 “百度翻译” 的爬虫代码 # python爬虫实现百度翻译 # urllib和request POST参数提交 from urllib import request,parse impor ...
- vue全家桶(2.6)
3.9.滚动行为 设置滚动行为的作用是导航到新路由时,让页面滚动到你想要的位置. const router = new VueRouter({ routes: [...], scrollBehavio ...
- Nginx配置upstream实现负载均衡1
如果Nginx没有仅仅只能代理一台服务器的话,那它也不可能像今天这么火,Nginx可以配置代理多台服务器,当一台服务器宕机之后,仍能保持系统可用.具体配置过程如下: 1. 在http节点下,添加ups ...
- jquery 获取页面和滚动条的高度
1.获取浏览器显示区域的高度 : $(window).height(); 2.获取浏览器显示区域的宽度 : $(window).width(); 3.获取页面的文档高度 : $(document).h ...
- pycham中报:ModuleNotFoundError: No module named 'pymysql'
参考https://www.cnblogs.com/wupeiqi/articles/5713330.html https://pypi.python.org/pypi # D:\Program Fi ...
- JasperReport报表中输出Excel时,部分列不显示的问题
JasperReport开源报表功能强大,是我们WEB系统中做报表开发的一个强有力的工具,上手也比较简单.我碰到的问题是进行报表输出时,在html网页中显示正常,但如果导出为Excel时,部分列不显示 ...
- SpringCloud 断路器之Hystrix
Hystrix-断路器 在分布式环境中,许多服务依赖项中的一些必然会失败.Hystrix是一个库,通过添加延迟容忍和容错逻辑,帮助你控制这些分布式服务之间的交互.Hystrix通过隔离服务之间的访问点 ...
- linux篇---根据端口号查看进程位置
1)说明:Linux的所有进程都保存在/proc/目录下,保存形式为:/proc/进程号.进入到进程号目录后,里面有一个cwd链接文件即指向的进程的的目录. 2) 操作: A:根据端口号查进程 如:l ...