stdout(标准输出),输出方式是行缓冲。输出的字符会先存放在缓冲区,等按下回车键时才进行实际的I/O操作。
stderr(标准错误),是不带缓冲的,这使得出错信息可以直接尽快地显示出来。
#include<stdio.h>
int main()
{
while(1)
{
fprintf(stdout,"Group");
fprintf(stderr,"XiyouLinux");
getchar();
}
}
在Linux环境下我们可以发现第一次会输出XiYouLinuxGroup,是因为stdout将输出的Group放到了缓冲区当中直到程序结束在将缓冲区中的数据刷新出来。
那么我们再看下一个例子
#include<stdio.h>
int main()
{
while(1)
{
fprintf(stdout,"Group\n");
fprintf(stderr,"XiyouLinux");
getchar();
}
}
输出结果为
Group
XiYouLinux
这是什么原因呢???这个属于stdout输出的第二种情况即遇到换行符(“\n”)时输出,因此在本例中顺序输出了该结果
#include<stdio.h>
void main()
{
int i;
for(i=1;i<=100000;i++)
{
fprintf(stdout,"Group");
fprintf(stderr,"XiYouLinux\n");
}
}
在电脑上面会一直输出末尾换行的XiYouLinux,直到stdout输出的字母数累计到1024后将这1024个字母输出,然后继续将末尾换行的XiYouLinux输出,接着等存够102输出,如此反复直到程序结束,将缓冲区中的剩余字母输出。
stdout和stderr还有很多其他的一些有趣的操作,在这里就不多作说明了,写这篇博客只是希望大家了解一些关于这两个的一些冷门知识。若有不对的地方还请多多指教。