write、fwrite、fstream二进制I/O的效率对比

测试数据

写文件测试数据

注:每项数据为3次运行的结果取平局值,运行时长为10ms。

|------------|--------|--------|---------------|
| 单次传入字节数(B) | 写入字节数(MB) |||
| 单次传入字节数(B) | write | fwrite | fstream.write |
| 1 | 0.005 | 0.124 | 0.127 |
| 4 | 0.019 | 0.453 | 0.450 |
| 16 | 0.064 | 1.840 | 1.860 |
| 64 | 0.363 | 4.503 | 4.277 |
| 256 | 0.900 | 7.753 | 9.490 |
| 512 | 1.880 | 8.797 | 10.220 |
| 1024 | 3.707 | 9.003 | 4.060 |
| 2048 | 5.733 | 8.930 | 5.157 |
| 4096 | 9.177 | 10.140 | 10.993 |
| 8192 | 10.023 | 10.853 | 13.727 |
| 16384 | 12.387 | 10.510 | 11.377 |
| 32768 | 13.280 | 12.967 | 13.333 |
| 65536 | 11.000 | 9.877 | 11.333 |

读文件测试数据

待补充......

结果分析

  1. 单次传入字节数小于1K时,write的效率与fwrite、fstream.write差距很大,在单次传入字节数大于等于4K后效率接近。
  2. 标准I/O库的fwrite接口和C++标准库的fstream.write接口写二进制文本的效率基本接近,但在单次传入字节数1K和2K时fwrite效率高于fstream.write。
相关推荐
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮1 天前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
样例过了就是过了1 天前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
谭欣辰1 天前
C++ 排列组合完整指南
开发语言·c++·算法
橙子也要努力变强1 天前
信号捕捉底层机制-机理篇2
linux·服务器·c++
盐焗鹌鹑蛋1 天前
【C++】stack和queue类
c++
郝学胜-神的一滴1 天前
罗德里格斯旋转公式(Rodrigues‘ Rotation Formula)完整推导
c++·unity·godot·图形渲染·three.js·unreal
lzh200409191 天前
深入理解进程:从PCB内核结构到写时拷贝的底层实战
linux·c++
aseity1 天前
跨平台项目中QString 与 非Qt 跨平台动态库在字符集上的一个实用的互操作约定.
c++·经验分享
CN-Dust1 天前
【C++】while语句例题专题
数据结构·c++·算法