庖丁解牛:NIO核心概念与机制详解 02 _ 缓冲区的细节实现

文章目录


Pre

庖丁解牛:NIO核心概念与机制详解 01


接下来我们来看下缓冲区内部细节

Overview

接下来将介绍 NIO 中两个重要的缓冲区组件:状态变量和访问方法 (accessor)

状态变量是"内部统计机制"的关键。每一个读/写操作都会改变缓冲区的状态。通过记录和跟踪这些变化,缓冲区就可能够内部地管理自己的资源。

在从通道读取数据时,数据被放入到缓冲区。在有些情况下,可以将这个缓冲区直接写入另一个通道,但是在一般情况下,您还需要

  • 查看数据。这是使用 访问方法 get() 来完成的。
  • 同样,如果要将原始数据放入缓冲区中,就要使用访问方法 put()。

状态变量

概述

可以用三个值指定缓冲区在任意时刻的状态:

  • position
  • limit
  • capacity

这三个变量一起可以跟踪缓冲区的状态和它所包含的数据。

我们将详细分析每一个变量,还要介绍它们如何适应典型的读/写(输入/输出)进程。在这个例子中,我们假定要将数据从一个输入通道拷贝到一个输出通道


Position


访问方法

相关推荐
小bo波10 天前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制
swordbob14 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
swordbob15 天前
NIO 的 Channel 里有多个 BIO 吗?
linux·网络·nio
starsky7623818 天前
NIO与BIO的区别
java·服务器·nio
东南门吹雪18 天前
JAVA TCP socket编程框架
java·高并发·socket·tcp·nio
JackSparrow41420 天前
彻底理解Java NIO(三)Java实现 I/O多路复用+Reactor模式及开源框架代码解读
java·c语言·开发语言·后端·nio·reactor模式
布朗克16820 天前
25 IO流高级操作——序列化、NIO与Files工具类
java·数据库·io·nio
不懂的浪漫23 天前
10|Netty native epoll 与零拷贝:从 Java NIO 再往下看一层![
java·netty·nio
许彰午23 天前
24_Java NIO核心组件
java·python·nio
C+++Python1 个月前
如何在 Java 中使用 BIO、NIO 和 AIO?
java·开发语言·nio