博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java io、java nio、netty的缓冲区比较
阅读量:6159 次
发布时间:2019-06-21

本文共 751 字,大约阅读时间需要 2 分钟。

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

你可能感兴趣的文章
下一步工作分配
查看>>
Response. AppendHeader使用大全及文件下载.net函数使用注意点(转载)
查看>>
jQuery最佳实践
查看>>
centos64i386下apache 403没有权限访问。
查看>>
jquery用法大全
查看>>
PC-BSD 9.2 发布,基于 FreeBSD 9.2
查看>>
css斜线
查看>>
Windows phone 8 学习笔记(3) 通信
查看>>
Revit API找到风管穿过的墙(当前文档和链接文档)
查看>>
Scroll Depth – 衡量页面滚动的 Google 分析插件
查看>>
Windows 8.1 应用再出发 - 视图状态的更新
查看>>
自己制作交叉编译工具链
查看>>
Qt Style Sheet实践(四):行文本编辑框QLineEdit及自动补全
查看>>
[物理学与PDEs]第3章习题1 只有一个非零分量的磁场
查看>>
onInterceptTouchEvent和onTouchEvent调用时序
查看>>
android防止内存溢出浅析
查看>>
4.3.3版本之引擎bug
查看>>
SQL Server表分区详解
查看>>
STM32启动过程--启动文件--分析
查看>>
垂死挣扎还是涅槃重生 -- Delphi XE5 公布会归来感想
查看>>