Netty:NIO buffer 原理(附 示例代码)

简介: Netty:NIO buffer 原理(附 示例代码)

Java:NIO buffer 原理理解

NIO 是同步,非阻塞

NIO 和 BIO 最大不同在于

BIO是面向流的

NIO是面向块(缓冲区)的

NIO将文件或文件中的一段区域映射到内存中,可以像访问内存一样访问文件

那么今天我们打卡点知识就是 java NIO 中的 缓冲区接口 Buffer


Buffer

我们以 cahrBuffer为例子

1.png



capacity 总体容量大小

limit 存储容量的大小,是可读写和不可读写的界线

position 已读容量的大小,已读和未读区域的界线


【使用原理】

a) 初始化,给定总容量,position=0, limit=capacity

b) 当使用put方法存入数据是,通过position来记录存储的容量变化,position不断后移,直到存储结束(写完成)

c)写完成需要调用flip方法刷新,limit=position,position=0

保障limit记录的是可读写区域的大小,position已读部分重置为空

d) 读数据直到读完成,需要调用clear方法,position=0, limit=capacity


【示例代码】

public class BufferTest {
    public static void main(String[] args) {
        CharBuffer charBuffer = CharBuffer.allocate(8);
        System.out.println("=========初始化");
        System.out.println("capacity:" + charBuffer.capacity());
        System.out.println("position:" + charBuffer.position());
        System.out.println("limit:" + charBuffer.limit());
        System.out.println("=========存储");
        charBuffer.put('h');
        charBuffer.put('y');
        charBuffer.put('c');
        System.out.println("position:" + charBuffer.position());
        System.out.println("limit:" + charBuffer.limit());
        charBuffer.flip();
        System.out.println("=========调用flip");
        System.out.println("position:" + charBuffer.position());
        System.out.println("limit:" + charBuffer.limit());
        System.out.println("=========读取数据");
        //没有参数就是读取第一个,且会用 position 记录
        //有参数 不会使用position记录
        //System.out.println(charBuffer.get());
        //System.out.println(charBuffer.get(1));
        //遍历方法
        //while (charBuffer.hasRemaining()) {
        //    System.out.println(charBuffer.get());
        //}
        //标记
        charBuffer.mark();
        System.out.println(charBuffer.get());
        System.out.println("position:" + charBuffer.position());
        System.out.println(charBuffer.get());
        System.out.println("position:" + charBuffer.position());
        //回退到标记的 position
        charBuffer.reset();
        System.out.println("========调用reset方法");
        System.out.println(charBuffer.get());
        System.out.println("position:" + charBuffer.position());
        System.out.println("limit:" + charBuffer.limit());
        charBuffer.clear();
        System.out.println("=========调用clear");
        System.out.println("position:" + charBuffer.position());
        System.out.println("limit:" + charBuffer.limit());
    }
}

根据上述的执行原理,我们查看结果

2.png




相关文章
|
4月前
|
Java 调度
Netty运行原理问题之ChannelHandler在Netty中扮演什么角色
Netty运行原理问题之ChannelHandler在Netty中扮演什么角色
|
4月前
|
编解码 网络协议 API
Netty运行原理问题之Netty的主次Reactor多线程模型工作的问题如何解决
Netty运行原理问题之Netty的主次Reactor多线程模型工作的问题如何解决
|
4月前
|
编解码 网络协议 开发者
Netty运行原理问题之NettyTCP的粘包和拆包的问题如何解决
Netty运行原理问题之NettyTCP的粘包和拆包的问题如何解决
|
4月前
|
调度
Netty运行原理问题之事件调度工作的问题如何解决
Netty运行原理问题之事件调度工作的问题如何解决
|
4月前
|
设计模式
Lettuce的特性和内部实现问题之Netty NIO的性能优于BIO的问题如何解决
Lettuce的特性和内部实现问题之Netty NIO的性能优于BIO的问题如何解决
|
6月前
|
存储 编解码 移动开发
技术笔记:NIO流—理解Buffer、Channel概念和NIO的读写操作
技术笔记:NIO流—理解Buffer、Channel概念和NIO的读写操作
43 1
|
1月前
|
消息中间件 缓存 Java
java nio,netty,kafka 中经常提到“零拷贝”到底是什么?
零拷贝技术 Zero-Copy 是指计算机执行操作时,可以直接从源(如文件或网络套接字)将数据传输到目标缓冲区, 而不需要 CPU 先将数据从某处内存复制到另一个特定区域,从而减少上下文切换以及 CPU 的拷贝时间。
java nio,netty,kafka 中经常提到“零拷贝”到底是什么?
|
2月前
|
Java
让星星⭐月亮告诉你,Java NIO之Buffer详解 属性capacity/position/limit/mark 方法put(X)/get()/flip()/compact()/clear()
这段代码演示了Java NIO中`ByteBuffer`的基本操作,包括分配、写入、翻转、读取、压缩和清空缓冲区。通过示例展示了`position`、`limit`和`mark`属性的变化过程,帮助理解缓冲区的工作原理。
36 2
|
3月前
|
Java
Netty BIO/NIO/AIO介绍
Netty BIO/NIO/AIO介绍
|
2月前
|
Java Linux 应用服务中间件
【编程进阶知识】高并发场景下Bio与Nio的比较及原理示意图
本文介绍了在Linux系统上使用Tomcat部署Java应用程序时,BIO(阻塞I/O)和NIO(非阻塞I/O)在网络编程中的实现和性能差异。BIO采用传统的线程模型,每个连接请求都会创建一个新线程进行处理,导致在高并发场景下存在严重的性能瓶颈,如阻塞等待和线程创建开销大等问题。而NIO则通过事件驱动机制,利用事件注册、事件轮询器和事件通知,实现了更高效的连接管理和数据传输,避免了阻塞和多级数据复制,显著提升了系统的并发处理能力。
70 0