为什么c++的输出比C慢得多

Why C++ output is too much slower than C?

本文关键字:c++ 输出 为什么      更新时间:2023-10-16

我其实是一个c++爱好者,但是今天我发现我的程序的文件输出非常慢。因此,我设计了一个实验来比较c++和C的文件输出速度。假设我们有这样一段代码:

int Num = 20000000;
vector <int> v;
for ( int i = 0; i < Num; i++ )
{
    v.push_back(i);
}

现在我运行两个单独的代码,一个在c++中:

int now = time(0);
cout << "start" << endl;
ofstream fout("c++.txt");
for(size_t i = 0; i < v.size(); ++i)
{
    fout<< v[i] << endl;
}
fout.close();
cout << time(0) - now << endl;

和C中的一个:

int now = time(0);
printf("startn");
FILE *fp = fopen("c.txt", "w");
for(size_t i = 0; i < v.size(); ++i)
{
    fprintf(fp, "%dn", v[i]);
}
fclose(fp);
printf("%ldn", time(0) - now);

c++程序出奇的慢!在我的系统上,C程序运行3秒,而c++程序运行大约需要50秒!对此有什么合理的解释吗?

这可能是因为您在c++代码中频繁地将流刷新到磁盘。在流中插入endl会插入新行并刷新缓冲区,而fprintf不会导致缓冲区刷新。

所以你的c++示例执行20,000,000次缓冲区刷新,而你的C示例只在文件句柄缓冲区满时才刷新磁盘。