【Netty】浅谈ByteBuf对JDK原生ByteBuffer之优化(一)

本文探讨了Java NIO中的Buffer组件,尤其是ByteBuffer,区分了HeapByteBuffer和DirectByteBuffer,解释了直接内存如何提升IO性能,并介绍了零拷贝的概念。文章通过分析数据传输过程,阐述了DirectByteBuffer在减少数据拷贝和状态切换中的作用,并引发了一个关于为何需要临时DirectByteBuffer的问题。
摘要由CSDN通过智能技术生成

写在前面

在Java NIO的体系中,Buffer是其中非常重要的一个组件,是通道Channel和消息数据之间传输的纽带,即:所有写操作必须将数据写到Buffer中,所有读操作必须从Buffer中读。这种做法相比较于传统的BIO基于字节/字符流的操作方式,利用缓冲区的作用,大大提高了IO的效率,但是这只是NIO优于BIO的其中一个方面,另外其他诸如多路复用器Selector,如果有兴趣,大家可以自己学习相关知识,这篇文章将主要从Buffer的角度来阐述一些NIO中的基本概念。

原生Buffer中的概念

在NIO的Buffer体系中最常用的就是ByteBuffer,下面的所有示例都是基于ByteBuffer来进行的。在写这篇博客之前,作者默认大家已经掌握了Buffer的基本用法,如allocate、put、get、flip、clear等方法,以及position、capacity、limit、mark等标记字段的含义等。那么,接下来我们就来深入探究JDK原生的ByteBuffer是如何提升IO性能的吧。我们先来看一下Buffer中的初始化方式,在ByteBuffer中共有两种初始化的方式,分别初始化两种不同类型的Buffer对象,分别为HeapByteBuffer和DirectByteBuffer。

public static ByteBuffer allocate(int capacity) {
   
	if (capacity < 0)
    	throw new IllegalArgumentException();
   return new HeapByteBuffer(capacity, capacity);
}
public 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值