首页 > 开发 > C++ > 正文

为什么输出换行都会消耗很多时间?

2017-09-11 21:35:45  来源: 网友分享

C语言中, printf("number\n") 比 printf("number") 、
C++中, std::cout << number << std::endl 比 std::cout << number 、
Python 中, print number 比 print number,
都要花上更多的时间,比如从一打印到一百万,
C中相差了7秒,C++ 5秒,Python 10秒(虽然python中后一种是把换行改成空格)。
请问为什么会这样?

解决方案

默认情况下stdout是行缓冲的,没有换行的话,程序会尽量缓存,直到某个阈值(比如1024)为止。缓存减少了与IO设备的交互,所以显然速度会更快。如果你在运行的时候把输出重定向文件(文件默认是全缓冲),估计就看不出差别了。