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

文章目录


Pre

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


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

Overview

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

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

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

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

状态变量

概述

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

  • position
  • limit
  • capacity

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

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


Position


访问方法

相关推荐
编啊编程啊程4 天前
【004】生菜阅读平台
java·spring boot·spring cloud·dubbo·nio
编啊编程啊程4 天前
兼职管理平台
java·spring boot·rpc·dubbo·nio
编程岁月5 天前
java面试-0136-BIO、NIO、AIO区别?
java·面试·nio
TitosZhang8 天前
BIO、NIO、AIO详解
java·redis·nio
编啊编程啊程10 天前
gRPC从0到1系列【20】
java·rpc·kafka·dubbo·nio
编啊编程啊程10 天前
gRPC从0到1系列【19】
java·spring boot·rpc·dubbo·nio
失散1312 天前
分布式专题——26 BIO、NIO编程与直接内存、零拷贝深入辨析
java·分布式·rpc·架构·nio·零拷贝
Yeats_Liao16 天前
Java网络编程(七):NIO实战构建高性能Socket服务器
java·网络·nio
编啊编程啊程16 天前
gRPC从0到1系列【6】
java·rpc·kafka·dubbo·nio
lifallen19 天前
Flink TCP Channel复用:NettyServer、NettyProtocol详解
大数据·flink·nio