java io、java nio、netty的缓冲区比较

java io

分类
io读按字节数量分,有两种:
1.每次读一个字节
2.每次读多(字节数组的大小)个字节


优缺点
1.每次读一个字节
缺点
频繁磁盘io 速度慢。

数据流
磁盘——》内存(一个字节)

2.每次读多个字节
优点 减少磁盘io 速度快。

数据流
磁盘——》缓冲区(内存)——》操作数据(操作缓冲区的数据)


代码
每次读一个字节和每次读多个字节的方法都是由业务流类(FileInputStream)提供。调用过程:
缓冲区流类BufferedInputStream——》业务流类FileInputStream——》native方法


总结
缓冲区流类包装了业务流类 + 字节数组。

java nio

优点
io 流是单向写读。

nio 通道是双向读写。具体是缓冲区可以改变读写模式(通过flip方法),实现原理是写的时候指针移动,读的时候归位。


数据流
大的框架和io差不多,也是由业务类FileDispatcherImpl来提供最终读多个字节的方法。当然,最终调用的是native方法。

nio 数据流:磁盘——》通道——》缓冲区ByteBuffer(内存)——》操作数据
io 数据流:磁盘——》流类——》缓冲区流类BufferedInputStream(包装了流类FileInputStream + 字节数组)——》操作数据

netty

java nio有两个问题:
1.字节数组大小固定,不能自动伸缩
2.需要手动调用flip()方法切换写读模式

如何解决以上两个问题?
1.两个指针 一个指向写 一个指向读
2.


堆缓冲区HeapByteBuf和映射缓冲区MapByteBuf

转载于:https://juejin.im/post/5cc0880ce51d456e6c732d06

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值