C++输入输出:iostream还是cstdio?

C++输入输出:iostream还是cstdio?iostream快还是cstdio快?切不可人云亦云,误了OI大事!cout和printf,cin和scanf,究竟谁快?赶快来看一看吧~^_^

本来博客的题目是 <iostream>还是<cstdio>?结果回头一看题目变成了 还是? 气死了(╯#-_-)╯(难道<>里面的被当做注释了吗)

经常说<cstdio>里面的函数比<iostream>里面的运算符快,事实真的如此吗?本蒟蒻今天亲自测试了一下。

环境:Win7 64bit,CPU主频:2.30GHz

说明:以下程序中,主函数返回值是I/O操作花费的时间,单位:ms(可以参考clock()函数的用法 )(另外,别喷控制台背景颜色和Dev-C++qwq)

思路:用一个1~100000的for循环重复进行I/O操作,并计时,就像把一塌纸摞起来以测一张纸的厚度一样。

一、输出

1.不加优化的cout:

C++输入输出:iostream还是cstdio?

循环十万次,输出i,用时15585ms。

2.加优化的cout:

C++输入输出:iostream还是cstdio?

用时仅为6867ms,测得ios::sync_with_stdio用时0ms。

3.加优化的cerr:

C++输入输出:iostream还是cstdio?

cerr不加缓冲区,所以较慢:10961ms。

4.至于printf:

C++输入输出:iostream还是cstdio?

足足用了31秒!还是不要用了。。。原因应该是cout输出的数据类型是编译时确定的,而printf是根据%d、%c、%p、%s等在运行时确定的,要花更多的时间。不过和电脑性能可能也有关系。

5.顺便说一下,加优化的cout再用

for(register int i=1;i<=100000;++i)

(register)优化用时6772ms,快了95ms;另外,觉不要自己写递归版的输出优化…不信可以试试。

二、输入

没办法一个一个数敲,果断决定从文件输入。

文件1.txt内容如下(内容为1~100000的每个整数):C++输入输出:iostream还是cstdio?

1.不加优化的cin:

C++输入输出:iostream还是cstdio?

只用了132ms。

2.加优化的cin:C++输入输出:iostream还是cstdio?

只用了21ms!

3.scanf:

C++输入输出:iostream还是cstdio?

用时93ms。

4.目前市面上有一种读入优化,本蒟蒻亲自试了试:

(1)使用getchar():

①不判断负号:

C++输入输出:iostream还是cstdio?

只用了31ms。

②判断负号:C++输入输出:iostream还是cstdio?

差别不大,30ms。

(2)使用加ios::sync_with_stdio(false)的cin.get():

C++输入输出:iostream还是cstdio?

用时32ms。

综上所述,输入输出都不要自己写优化了,原生的就是最好的,用了万能的

ios::sync_with_stdio(false);

后,cin、cout就可以带OIer们起飞了。(建议32位系统的julao们自己也测试一下。QAQ)

后记一:

所谓

ios::sync_with_stdio(false);

,指的是让cin、cout放飞自我,不用与stdio同步(sync,synchronize/ˈsɪŋkrənaɪz/,同步)。后果是:如果一边用cin、cout,一边用scanf、printf,就像这样:

#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
	ios::sync_with_stdio(false);
	for(int i=1;i<=100000;++i)cout<<i<<' ',printf("%d\n",i);
	return 0;
}

期望结果:

......
99993 99993
99994 99994
99995 99995
99996 99996
99997 99997
99998 99998
99999 99999
100000 100000

但是实际结果是这样的:

C++输入输出:iostream还是cstdio?

各按各的套路出牌。。。完全不在一个频道上。。。(虽然都向stdout写入)

看清楚“同步”的作用了吧!所以,要抛弃stdio,就要抛地彻底,不留痕迹!qwq

后记二:

还有一个意想不到的事实!对于输出时换行这件事情,本蒟蒻又有了新的发现:

这是不换行的结果:C++输入输出:iostream还是cstdio?

用时629ms;

这是用’\n’换行的结果:

C++输入输出:iostream还是cstdio?

用时2068ms;

这是用endl换行的结果:

C++输入输出:iostream还是cstdio?

就像前面提到的,用时6s多(同一个代码不同时间测试结果稍有不同)。

发现’\n’快了好多!

原因大概是endl调用了flush(冲厕所|刷新缓冲区)函数,浪费了一些时间:

C++输入输出:iostream还是cstdio?

所以换行不要用endl啦!

(此外,把’\n’改为”\n”,稍稍慢了一点,约100ms)

后记三:

有同学说cout重定向到文件,效率会大打折扣?本蒟蒻又试了一下。

这次数据规模1e6。输出文件:1.txt。

(一)一开始文件不存在

1.cout+ios::sync_with_stdio(false)+endl:

C++输入输出:iostream还是cstdio?

13.65s。

2.printf:

C++输入输出:iostream还是cstdio?

只用了0.9112s!什么?cout跌落神坛?这究竟是人性的泯灭还是道德的沦丧?

3.别急,我说过,endl是个坑,不要故意往里跳。

cout+ios::sync_with_stdio(false)+’\n’:

C++输入输出:iostream还是cstdio?

哈哈,printf败下阵来!0.4732s!

(二)一开始已经有1.txt文件

这种情况下花的时间要多,大概是因为要把原文件地址重新标记为可写,就像彻底删除文件,虽然只是标记为可写,但也需要一定的时间。

我们只需比较cout+’\n’和printf。

但是遇到了一些问题,由于每次结果不同,出现了有时cout快、有时printf快的情况,不过无伤大雅,因为CSP中不存在评测前就有*.out的情况。

总之,cout才是王道,又笨又慢还不安全的printf,再见啦!

要点总结:

1.用cin、cout,而不是scanf、printf;

2.用ios::sync_with_stdio(false),而不是nothing;

3.用’\n’,而不是endl。

其他关于卡常的技巧可以参观:

玄学卡常


完结撒花!(觉得有帮助别忘了点个赞哦!^_^)

C++输入输出:iostream还是cstdio?

今天的文章C++输入输出:iostream还是cstdio?分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/10295.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注