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

C++输入输出:iostream还是cstdio?本测试对比了 C 中 iostream 与 cstdio 库的 I O 性能 实验显示 经过适当优化 cin 和 cout 在输入输出速度上超越了 scanf 和 printf 尤其是 cstdio iostream

大家好,欢迎来到IT知识分享网。

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

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

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

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

思路:用一个1~的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<=;++i)

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

二、输入

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

文件1.txt内容如下(内容为1~的每个整数):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<=;++i)cout<<i<<' ',printf("%d\n",i); return 0; }

期望结果:

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

但是实际结果是这样的:

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?

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/119829.html

(0)
上一篇 2025-11-02 19:15
下一篇 2025-11-02 19:26

相关推荐

发表回复

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

关注微信