Подтвердить что ты не робот

Почему вывод С++ слишком медленный, чем C?

Я на самом деле являюсь поклонником С++, но сегодня я вычислил очень медленный выход файла моей программы. Итак, я разработал эксперимент для сравнения скорости вывода файла С++ с C. Предположим, что у нас есть эта часть кода:

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

Теперь я запускаю два отдельных кода, один в С++:

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 запускается через 3 секунды, а программа на С++ занимает около 50 секунд! Есть ли разумное объяснение этому?

4b9b3361

Ответ 1

Вероятно, из-за того, как часто вы очищаете поток на диске в коде С++. Вставка endl в поток вставляет новую строку и очищает буфер, а fprintf не вызывает сброс буфера.

Итак, ваш пример С++ выполняет 20 000 000 сбросов буферов, в то время как ваш пример C будет только сбрасываться на диск, когда файл обрабатывает буфер.