为什么C ++输出过慢得多比C?(Why C++ output is too much slower

2019-09-01 19:50发布

我其实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("start\n");
FILE *fp = fopen("c.txt", "w");
for(size_t i = 0; i < v.size(); ++i)
{
    fprintf(fp, "%d\n", v[i]);
}
fclose(fp);
printf("%ld\n", time(0) - now);

C ++程序的工作原理出奇慢! 在我的系统,C计划在3秒内运行,而C ++程序大约需要50秒钟的运行! 对此有任何合理的解释?

Answer 1:

这可能是因为您是如何经常刷新流在C ++代码盘。 插入endl到一个流中插入新行,并刷新缓冲区,而fprintf不引起缓冲器平齐。

所以,你的C ++例子,而你的C例子只会刷新到磁盘时的文件处理缓冲区已满执行20000000次缓冲区刷新。



文章来源: Why C++ output is too much slower than C?