stdout和stderr关于缓冲区的浅解

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还有很多其他的一些有趣的操作,在这里就不多作说明了,写这篇博客只是希望大家了解一些关于这两个的一些冷门知识。若有不对的地方还请多多指教。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章