最近在学习Netty底层的实现原理,也就是NIO编程,在这里学习了NIO三大概念中的Buffer,下面记录下学习的笔记
- Buffer:NIO中的Buffer实际上是数组,给各种各样数据类型都定义了相依的数组缓冲区(除了boolean).除此之外NIO是通过Buffer来进行数据的传输的,区别于传统的IO(通过Stream的方式来进行IO操作)
- Buffer类型:
- ByteBuffer
- CharBuffer
- ShortBuffer
- IntBuffer
- LongBuffer
- FloatBuffer
- DoubleBuffer
- Buffer之变量:Buffer定义了三个变量来描述其状态
- pos:定位(理解成index,指向写入数据后的下一个索引)
- limit:数据个数
- capacity:缓冲区容量
- 下面是学习demo
public class Buffer { public static void main(String[] args) { IntBuffer intBuffer = IntBuffer.allocate(1024); System.out.println(intBuffer); intBuffer.put(1); intBuffer.put(2); intBuffer.put(3); System.out.println(intBuffer); intBuffer.flip(); System.out.println(intBuffer); } }
- 测试结果
java.nio.HeapIntBuffer[pos=0 lim=1024 cap=1024] java.nio.HeapIntBuffer[pos=3 lim=1024 cap=1024] java.nio.HeapIntBuffer[pos=0 lim=3 cap=1024]
- 总结:当我们初始定义Buffer时,cap(容量)就初始化了相应的大小,同时lim会将Buffer中所有单位的数据当作是0,所以lim也显示1024.由于没有对Buffer进行写入操作,所以pos不会有变化。当我们执行put操作后,对Buffer进行了操作,pos就进行了移动。当我们调用flip(复位)方法时,其底层过程就是lim=pos;pos=0;,所以最后pos又被置零了,复位操作方便我们后续遍历的时候使用pos,否则会出现溢出异常。