转载:http://blog.sina.com.cn/s/blog_495935980100bs89.html
今天无意中发现cout和printf是有点区别的,一个是输出语句,一个是输出函数
我编了个函数如下:
#include "iostream.h"
#include "stdio.h"
main()
{
}
运行结果如下:
++++++++++++
++++++++++++
############
############
@@@@@@@@@@@
============
============
cout先是把输出结果存到缓存区,然后一次性输出,其实COUT输出的时候也是调用了printf函数;
pintf函数是每次输出结果;
这就是为了么在TIME程序中cout运行的时间要比printf函数快的原因;
当时有一点需要注意:cout<<"============\n";和cout<<"============"<<endl;也有不同,\n只是一个字符,而endl会将缓存区的数据全部输出并清零;在TIME程序中,如果采用cout<<"============"<<endl;结构反而会比Printf慢,因为多了一道调用缓存手续
下面打个很形象的比喻,大家都会明白
比如有100个鸡蛋,需要从A拿到B点,相当于程序中的输出
Printf把鸡蛋一次一个用手拿到B点
cout<<"
cout<<"
尤其可见哪个快那个慢显而易见