Я пытался записать данные файла как можно быстрее.
- Я увеличил размер буфера, чтобы уменьшить количество операций ввода-вывода.
- Я протестировалс fstream и fopen.
По какой-то причине fstream быстрее, чем fopen.
- в 64-байтовом буфере, он в ~ 1,3 раза быстрее
- вкл.8192-байтовый буфер работает в ~ 4,8 раза.
Я слышал, что файловый ввод / вывод C быстрее (что имеет смысл)
<fstream>
включает <stdio.h>
, но я могуfopen не работает так быстро.
ПРИМЕЧАНИЕ (старые вопросы):
- мой fopen был в 2 раза медленнее fstream, потому что я использовал fprintf (спасибо jamesdlin )
- буфер fstream не изменился, так как вы должны установить его перед открытием (спасибо Пол Сандерс )
также реализован fstream.put (char)быстрее, чем fstream << char <br>(иначе fopen быстрее, чем fstream, если буфер <~ 256) </p>
Вот мое тестирование:
#include <iostream>
#include <fstream>
#include <ctime>
int filesize; // total bytes (individually "put" in buffered stream)
int buffsize; // buffer size
void writeCPP(){
std::ofstream file;
char buffer[buffsize]; file.rdbuf()->pubsetbuf(buffer,buffsize); // set buffer (before opening)
file.open("test.txt",std::ios::binary); // open file
for(int i=0; i<filesize; i++) file.put('a'); // write bytes
file.close(); // close
}
void writeC(){
FILE* file=fopen("test.txt","wb"); // open file
char buffer[buffsize]; setvbuf(file,buffer,_IOFBF,buffsize); // set buffer
for(int i=0; i<filesize; i++) fputc('a',file); // write bytes
fclose(file); // close
}
#define getTime() double(clock())/CLOCKS_PER_SEC // good enough
double start;
void test(int s){ // C++ vs C (same filesize / buffsize)
buffsize=s;
std::cout<<" buffer: "<<buffsize<<"\t"<<std::flush;
start=getTime();
writeCPP();
std::cout<<" C++: "<<getTime()-start<<",\t"<<std::flush;
start=getTime();
writeC();
std::cout<<" C: "<<getTime()-start<<std::endl;
}
#define MB (1024*1024)
int main(){
filesize=10*MB;
std::cout<<"size: 10 MB"<<std::endl;
// C++ fstream faster
test(64); // C++ 0.86 < C 1.11 (1.29x faster)
test(128); // C++ 0.44 < C 0.79 (1.80x faster) (+0.51x)
test(256); // C++ 0.27 < C 0.63 (2.33x faster) (+0.53x)
test(512); // C++ 0.19 < C 0.56 (2.94x faster) (+0.61x)
test(1024); // C++ 0.15 < C 0.52 (3.46x faster) (+0.52x)
test(2048); // C++ 0.14 < C 0.51 (3.64x faster) (+0.18x)
test(4096); // C++ 0.12 < C 0.49 (4.08x faster) (+0.44x)
test(8192); // C++ 0.10 < C 0.48 (4.80x faster) (+0.72x)
}