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

文章目录


Pre

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


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

Overview

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

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

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

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

状态变量

概述

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

  • position
  • limit
  • capacity

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

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


Position


访问方法

相关推荐
众纳4 天前
Spring Boot 从Socket 到Netty网络编程(上):SOCKET 基本开发(BIO)与改进(NIO)
nio·bio·java socket·java bio·java nio·java 网络编程
EdmundXjs6 天前
IO Vs NIO
java·开发语言·nio
苗内15 天前
CloudWeGo-Netpoll:高性能NIO网络库浅析
网络·nio
蚰蜒螟15 天前
剖析 Spring 中 @ResponseBody 原理与 Tomcat NIO 写事件(SelectionKey.OP_WRITE)的协作机制
spring·tomcat·nio
残*影17 天前
BIO、NIO、AIO 的区别与实战应用解析
nio
快乐肚皮17 天前
Netty学习专栏(一):Java NIO编程与核心组件详解
java·学习·nio
RubyWinner17 天前
网络编程 之 从BIO到 NIO加多线程高性能网络编程实战
java·网络·nio
面向AI编程的小白18 天前
【BIO、NIO、AIO的区别?】
nio
SSSYUsssyu18 天前
Java NIO(New I/O)
java·开发语言·nio
从零开始学习人工智能18 天前
深入解析异步编程:Java NIO、Python `async/await` 与 C# `async/await` 的对比
java·python·nio