格式化输出 printf 与 输出流 cout   2010-09-25


printf 是 格式化输出 , cout 是输出流

今天无意中发现 cout 和 printf 是有点区别的,一个是输出语句,一个是输出函数

demo

#include <iostream.h>
#include <stdio.h>

int main() {

for(int a=0; a<24; a++) {

printf("++++++++++++\n");
cout << "============\n";
printf("############\n");
}
printf("@@@@@@@@@@@\n");
}

运行结果如下:

++++++++++++

++++++++++++

############

############

@@@@@@@@@@@

============

============

原因分析

cout 先是把输出结果存到缓存区,然后一次性输出,其实 cout 输出的时候也是调用了printf函数;
pintf函数是每次输出结果; 这就是为了在 TIME程序中 cout运行的时间要比printf函数快的原因;

注意: cout<<”==\n”; 和 cout<<”==”<<endl; 也有不同,\n只是一个字符,而endl会将缓存区的数据全部输出并清零;在TIME程序中,如果采用cout<<”============”<<endl;结构反而会比printf慢,因为多了一道调用缓存手续

形象比喻

下面打个很形象的比喻,大家都会明白, 比如有100个鸡蛋,需要从A拿到B点,相当于程序中的输出:

  • printf把鸡蛋一次一个用手拿到B点
  • cout<<” \n” 先把鸡蛋全部放到篮子,然后一次性拿过去取出
  • cout<<” “<<endl 先把鸡蛋放到篮子,然后一次一个拿过去再取出

尤其可见哪个快那个慢显而易见


分享到:


  如果您觉得这篇文章对您的学习很有帮助, 请您也分享它, 让它能再次帮助到更多的需要学习的人. 您的支持将鼓励我继续创作 !
本文基于署名4.0国际许可协议发布,转载请保留本文署名和文章链接。 如您有任何授权方面的协商,请邮件联系我。

Contents

  1. demo
  2. 原因分析
  3. 形象比喻