java io读取性能对比
背景
从最早bio的只支持阻塞的bio(同步阻塞)
到默认阻塞支持非阻塞nio(同步非阻塞+同步阻塞)(此时加入mmap类)
再到aio(异步非阻塞)
虽然这些api改变了调用模式,但真正执行效率上是否也会有所不同,对此进行了此次java io的性能测试
首先从github上找到了2个项目,然后自己也实现了一个性能对比的实现,以便熟悉各种api
项目1:
https://github.com/stateIs0/io.benchmark
https://www.jianshu.com/u/434239413000
其中filechannel生成文件的代码就是错误的,其实文件中并没有内容

左边没有填入内容,右边是正确的
项目2:
https://github.com/romromov/java-io-benchmark
比较了不同物理硬件上,不同的api的性能差异
可以指定fileSize bufferSize 以及重复的次数 ,并且可以输出平均数和标准差
项目3:
https://github.com/victorsheng/benchmark-anything/tree/master/io-bencmmark
自己的io测试项目
发现mmap必须一次性读取,整个文件才能发挥应有的效果
但是同时整个buffer必须小于Integer.MAX_VALUE 因此,只能适用2G以下的文件,在多次申请小buffer的mmap情况下,性能非常差
硬件
mac系统 ssd硬盘
测试结果
读取:
file size:1024MB buffer size:1024B
InputStreamFileReader,1908
BufferedInputStreamFileReader,2013
InDirectBufferFileChannelReader,1935
DirectBufferFileChannelReader,1722
MultiMmapFileReader,13108
OneMmapFileReader,1231
RandomAccessFileReader,1941
file size:1024MB buffer size:4096B
InputStreamFileReader,606
BufferedInputStreamFileReader,614
InDirectBufferFileChannelReader,639
DirectBufferFileChannelReader,616
MultiMmapFileReader,5341
OneMmapFileReader,1287
RandomAccessFileReader,707
file size:1024MB buffer size:16384B
InputStreamFileReader,360
BufferedInputStreamFileReader,357
InDirectBufferFileChannelReader,371
DirectBufferFileChannelReader,368
MultiMmapFileReader,1905
OneMmapFileReader,1552
RandomAccessFileReader,405
写:
file size:1GB,buffer size:1KB
OutPutFileWriter,5972
BufferedOutPutFileWriter,1631
InDirectBufferFileChannelFileWriter,7021
DirectBufferFileChannelFileWriter,6781
OneMmapFileWriter,1373
MultiMmapFileWriter,26122
RandomAccessFileWriter,6118
file size:1GB,buffer size:4KB
OutPutFileWriter,2438
BufferedOutPutFileWriter,1454
InDirectBufferFileChannelFileWriter,2449
DirectBufferFileChannelFileWriter,3177
OneMmapFileWriter,1365
MultiMmapFileWriter,9124
RandomAccessFileWriter,2331
file size:1GB,buffer size:16KB
OutPutFileWriter,1131
BufferedOutPutFileWriter,1048
InDirectBufferFileChannelFileWriter,1479
DirectBufferFileChannelFileWriter,1606
OneMmapFileWriter,1338
MultiMmapFileWriter,3652
RandomAccessFileWriter,1093
其中,第一列实现,第二列文件大小,第三列时间差
java io读取性能对比的更多相关文章
- lua、groovy嵌入到java中的性能对比(转)
lua和groovy都是可以嵌入到java中的脚本语言.lua以高性能著称,与C/C++在游戏开放中有较多使用,groovy是一个基于Java虚拟机(JVM)的敏捷动态语言,在jvm下有着不错的性能. ...
- 2017年的golang、python、php、c++、c、java、Nodejs性能对比(golang python php c++ java Nodejs Performance)
2017年的golang.python.php.c++.c.java.Nodejs性能对比 本人在PHP/C++/Go/Py时,突发奇想,想把最近主流的编程语言性能作个简单的比较, 至于怎么比,还是不 ...
- 2017年的golang、python、php、c++、c、java、Nodejs性能对比[续]
2017年的golang.python.php.c++.c.java.Nodejs性能对比[续] 最近忙,这个话题放了几天,今天来个续集. 上篇传送门: 2017年的golang.python.p ...
- java数据库连接池性能对比
这个测试的目的是验证当前常用数据库连接池的性能. testcase Connection conn = dataSource.getConnection(); PreparedStatement st ...
- [java]序列化框架性能对比(kryo、hessian、java、protostuff)
序列化框架性能对比(kryo.hessian.java.protostuff) 简介: 优点 缺点 Kryo 速度快,序列化后体积小 跨语言支持较复杂 Hessian 默认支持跨语言 较慢 Pro ...
- java io 读取写文件
java 读取txt文件,汉字乱码,原因是因为文件的编码格式和程序编码采用了不同的编码格式.通常,假如自己不修改的话,windows自身采用的编码格式是gbk(而gbk和gb2312基本上是一样的编码 ...
- java -io 读取文件操作
主要分为字节读取和字符读取,字节读取可以一个一个读取和字节数组读取,字符读取同样之,字符读取适合文本读取,字节读取皆可以 这里直接上代码,读取文件的9个小demo package com.io; im ...
- Java IO读取文件之二
package com.lf.iopreoject; import java.io.BufferedReader; import java.io.File; import java.io.FileIn ...
- Java模板引擎性能对比
模板引擎性能对比 从Github上翻到对JSP.Thymeleaf 3.Velocity 1.7.Freemarker 2.3.23几款主流模板的性能对比,总体上看,Freemarker.Veloci ...
随机推荐
- 基于C#的机器学习--微基准测试和激活功能
本章我们将学习以下内容: l 什么是微基准测试 l 如何将它应用到代码中 l 什么是激活函数 l 如何绘制和基准测试激活函数 每个开发人员都需要有一个好的基准测试工具.质量基准无处不在;你们每 ...
- UNICODE环境下读写txt文件操作
内容转载自http://blog.sina.com.cn/s/blog_5d2bad130100t0x9.html UNICODE环境下读写txt文件操作 (2011-07-26 17:40:05) ...
- baserecyclerviewadapterhelper -- setOnItemChildClickListener出现的问题
出现问题 使用baserecyclerviewadapterhelper 的时候使用 adapter.setOnItemChildClickListener()方法,点击没有反应. adapter.s ...
- JavaScript数组高性能去重解决方案
在大多数的人眼里,数组去重是一个很简单的课题,很多人甚至熟练掌握了多种数组去重的方法,然而大多时候,我们却忽略了数组去重所消耗的时间资源.譬如我们在做前端性能优化的时候,又有多少人会考虑JavaScr ...
- 《C# 语言学习笔记》——定义属性
属性定义的方式与字段类似,但包含的内容比较多. 属性拥有两个类似于函数的块,一个块用于获取属性的值,另一个块用于设置属性的值.这两个块也称访问器,分别用于get和set关键字定义,可以用于控制对属性的 ...
- pycharm remote debug
换工作了好久没写blog了,堕落了,哈哈,发现了好的东西分享一下,和以前使用的pycharm的远程debug相比,更为方便,原理同步本地和远程的代码,加载远程的环境运行,使用本地的代码+远程的环境,方 ...
- 2019牛客暑期多校训练营(第四场)J-free
>传送门< 题意:给你n个城市,m条道路,经过每一条要花费这条路的代价,现给你k个机会,使得最多k条路的代价为0,问从起点s到终点t花费的最少代价 思路:分层图最短路经典裸题 方法一 Co ...
- solr配置分词器
一.solr4.10 + mmseg4j-2.2.0分词器 1.solr的安装部署:http://www.cnblogs.com/honger/p/5876289.html,注意不同的版本安装方式可能 ...
- 走近OPENCV // opencv 2.4.9+vs2013配置
一直很懒去配opencv,这几周忍不了终于抽空来配了一下环境... 用的是旧版opencv2.4系列,最新到3.0了,之后再看看教程不知道有什么特别大的区别. (FF14国服没有4.0 // 8.19 ...
- es6,@import一直报错 Can't resolve。。
最近在项目中新增了一个按钮组的组件页面,但是在其他页面引入时,一直报错 引入方式: