为什么c++的输出比C慢得多
Why C++ output is too much slower than C?
我其实是一个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示例只在文件句柄缓冲区满时才刷新磁盘。
相关文章:
- 递归函数计算序列中的平方和(并输出过程)
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 请解释"函数1(p1,p2,p3);"的输出
- C++:将控制台输出存储在宏中更好吗
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 为什么我的代码在输出中增加了93天
- 如何从void函数输出字符串
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- AES加密到解密未正确输出
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- C++格式化输出问题
- 将值从二维数组输出到文本文件
- 集合上的输出迭代器:assign和increment迭代器
- 在while循环中输入带有std::cin的字符串后,控制台会输出大量胡言乱语
- 为什么rk4.do_step不输出C++中的初始条件
- 输出没有重复元素的动态数组(收缩数组)C++
- 如何根据单词在文本中出现的概率输出单词