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。
相关推荐
汉克老师6 分钟前
GESP6级C++考试语法知识(四、图与树(四))
c++·贪心算法·优先队列·哈夫曼编码·哈夫曼树·gesp6级·gesp六级
子兮曰1 小时前
whisper.cpp 深度解析:从边缘设备到实时语音识别
前端·c++·后端
特种加菲猫1 小时前
二叉搜索树:数据世界的“快速寻路指南”
开发语言·c++
naturerun1 小时前
从数组中删除元素的算法
数据结构·c++·算法
特种加菲猫1 小时前
STL关联容器:Set/Multiset与Map/Multimap详解
开发语言·c++
Andy1 小时前
C++ list容器基本逻辑结构详解
c++·windows·list
想唱rap3 小时前
传输层协议TCP
linux·运维·服务器·网络·c++·tcp/ip
瑶池酒剑仙3 小时前
C++类和对象完全指南:从封装继承多态到内存布局的面向对象宝典(雨夜论道)
c语言·开发语言·c++·visual studio
潇湘散客4 小时前
CAX软件插件化设计实现牛刀小试
c++·算法·图形学·opengl
Ricky_Theseus4 小时前
const 和 #define 的区别
c++