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

文章目录


Pre

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


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

Overview

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

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

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

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

状态变量

概述

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

  • position
  • limit
  • capacity

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

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


Position


访问方法

相关推荐
杨凯凡10 小时前
【019】IO/NIO 概念:Web 开发要掌握到什么程度
java·开发语言·nio
佛祖让我来巡山1 天前
Netty入门|从BIO到Netty:一步步看懂Java网络编程的迭代逻辑
netty·nio·bio
devilnumber4 天前
java的NIO框架Netty、Mina、Grizzly 和 Jetty 四种对比
java·nio·java面试·jetty
四斤年华5 天前
关于SpringBoot在MultipartFile上java.nio.file.NoSuchFileException: /tmp/undertow
java·spring boot·nio
大G的笔记本6 天前
BIO(Blocking I/O) 和 NIO(Non‑Blocking I/O) 两种不同的 I/O 模型
java·nio
野生技术架构师8 天前
Java NIO到底是个什么东西?
java·开发语言·nio
小红的布丁8 天前
BIO、NIO、AIO 与 IO 多路复用:select、poll、epoll 详解
java·数据库·nio
大数据新鸟10 天前
NIO 三大核心组件
服务器·网络·nio
橘子hhh12 天前
Netty基础服务器实现
java·nio
ayt00713 天前
Netty AbstractNioChannel源码深度剖析:NIO Channel的抽象实现
java·数据库·网络协议·安全·nio