c++ - 为什么 C++ 输出比 C 慢太多?

标签 c++ c performance io

我实际上是 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 秒! 这有什么合理的解释吗?

最佳答案

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

因此,您的 C++ 示例执行 20,000,000 次缓冲区刷新,而您的 C 示例仅在文件句柄缓冲区已满时才刷新到磁盘。

关于c++ - 为什么 C++ 输出比 C 慢太多?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16351339/

相关文章:

Java-paintComponent从数组中绘制数百万个正方形的最有效方法

c++ - 更新标签文本 GTK+ C++

c++ - 工作组障碍不起作用

c++ - 共享内存进程间通信

c++ - 使用 C 调用 PostgreSQL 存储过程

c - 既不是参数也不是指针

无法在腻子中正确显示十六进制值

c - 如何找到每个大小为 n 的 m 个数组的最长公共(public)子数组?

mysql - 如何在 MySQL 中测试没有结果的查询速度

c++ - 是什么让这个程序处理缓慢? (C++)