stdout, stdin, stderr的中文名字分别是标准输出,标准输入和标准错误。linux
在Linux下,当一个用户进程被建立的时候,系统会自动为该进程建立三个数据app
流,也就是题目中所提到的这三个。那么什么是数据流呢(stream)?咱们知道,一个程序要运行,须要有输入、输出,若是出错,还要能表现出自身的错误。这是就要从某个地方读入数据、将数据输出到某个地方,这就够成了数据流。ide
所以,一个进程初期所拥有的这么三个数据流,就分别是标准输出、标准输入和标准错误,分别用stdout, stdin, stderr来表示。对于这三个数据流来讲,默认是表如今用户终端上的,好比咱们在c中使用fprintf:spa
fprintf(stdout,"hello world!\n");orm
屏幕上将打印出"hello world!"来,一样,咱们使用:排序
上面的代码会接收用户输入在终端里的字符,并存在ptr中。进程
fread(ptr,1,10,stdin);it
那么标准输入输出和错误是否是只能反应在终端里呢?答案是否是的!咱们能够io
将标准输入和输出重定位到文件中:class
例如,咱们使用ls命令,会把当前目录下的文件名输出到终端上:
$ls
gcc gcc.sh gmp-5.0.1 gmp-5.0.1.tar.bz2
linux-loongson-community-2.6.35-rc1 longene-0.3.0-linux-2.6.34
mpfr-3.0.0 mpfr-3.0.0.tar.gz oprofile-0.9.6
咱们可使用“ > ”符号,将ls的标准输出重定向到文件中:
$ls > lsout ////////将标准输出重定向为文件lsout
$more lsout ////////显示lsout文件里的内容
gcc gcc.sh gmp-5.0.1 gmp-5.0.1.tar.bz2
linux-loongson-community-2.6.35-rc1 longene-0.3.0-linux-2.6.34
mpfr-3.0.0 mpfr-3.0.0.tar.gz oprofile-0.9.6
一样,咱们也可使用“ < ”符号将标准输入重定向到文件中,以sort为例,如下示例使用 sort命令对由键盘键入的文本进行排序。键入ctrl-D 结束标准输入。终端屏幕显示的标准输出以下:
$sort
muffy
happy
bumpy
CTRL-D //结束标准输入。
bumpy
happy
muffy //结束标准输出。
使用" < "重定向后为:
$ more socks 显示 socks的内容。
polka dot
argyle
plaid
$ sort < socks 将输入重定向为从 socks输入,并将内容排序。
argyle
plaid
polka dot
好,基本知识讲完了,咱们知道,标准输出和标准错误默认都是将信息输出到终端上,那么他们有什么区别呢?让咱们来看个题目:
问题:下面程序的输出是什么?(intell笔试2011)
Int main(){
fprintf(stdout,"Hello ");
fprintf(stderr,"World!");
return0;
}
解答:这段代码的输出是什么呢?你能够快速的将代码敲入你电脑上(固然,拷贝更快),而后发现输出是
World! Hello
这是为何呢?在默认状况下,stdout是行缓冲的,他的输出会放在一个buffer里面,只有到换行的时候,才会输出到屏幕。而stderr是无缓冲的,会直接输出,举例来讲就是printf(stdout, "xxxx") 和 printf(stdout, "xxxx\n"),前者会憋住,直到遇到新行才会一块儿输出。而printf(stderr, "xxxxx"),无论有么有\n,都输出。