sdtout、stderr

stdout(标准输出),输出方式是行缓冲。输出的字符会先存放在缓冲区,等按下回车键时才进行实际的I/O操作。

stderr(标准错误),是不带缓冲的,这使得出错信息可以直接尽快地显示出来。

1
2
3
4
5
6
7
8
9
10
#include<stdio.h>
int main()
{
while(1)
{
fprintf(stdout,"Group");
fprintf(stderr,"XiyouLinux");
getchar();
}
}

在Linux环境下我们可以发现第一次会输出XiYouLinuxGroup,是因为stdout将输出的Group放到了缓冲区当中直到程序结束在将缓冲区中的数据刷新出来。

那么我们再看下一个例子

1
2
3
4
5
6
7
8
9
10
#include<stdio.h>
int main()
{
while(1)
{
fprintf(stdout,"Group\n");
fprintf(stderr,"XiyouLinux");
getchar();
}
}

输出结果为

1
2
Group
XiYouLinux

这是什么原因呢???这个属于stdout输出的第二种情况即遇到换行符(“\n”)时输出,因此在本例中顺序输出了该结果

1
2
3
4
5
6
7
8
9
10
#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输出,接着等存够1024输出,如此反复直到程序结束,将缓冲区中的剩余字母输出。

Donate? comment?