大佬教程收集整理的这篇文章主要介绍了c – 使用MS Compiler极慢的std :: cout,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
#include <iostream> #include <chrono> using namespace std; #define TO_SEC(TimE) \ chrono::duration_cast<chrono::duration<double> >(TimE).count(); const int REPEATS = 100000; int main() { auto start_time = chrono::steady_clock::Now(); for (int i = 1; i <= REPEATS; i++) cout << '\r' << i << "/" << REPEATS; double run_time = TO_SEC(chrono::steady_clock::Now() - start_timE); cout << endl << run_time << "s" << endl; }
现在,使用MinGW(“g source.cpp -std == c 11”)编译时得到的输出是:
100000/100000 0.428025s
现在,使用Visual C Compiler 2013年11月(“cl.exe source.cpp”)编译时得到的输出是:
100000/100000 133.991s
这是非常荒谬的.我想到的是VC正在进行不必要的冲洗.
有人会知道如何防止这种情况吗?
编辑:设置是:
gcc版本4.8.2(GCC),目标i686-pc-cygwin
适用于x86的Microsoft(R)C/C++优化编译器版本18.00.21005.1
Windows 7 Professional N 64位,cpu i7-3630QM,2.4GHz,内存8.00GB
@H_205_5@microsoft建议修复此问题(在cout / stdout上启用缓冲):
setvbuf(stdout,_IOLBF,4096)
你也可以尝试:
cout.sync_with_stdio(false);
但可能它不会有所作为.
以上是大佬教程为你收集整理的c – 使用MS Compiler极慢的std :: cout全部内容,希望文章能够帮你解决c – 使用MS Compiler极慢的std :: cout所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。