简单理解Linux的1和2操作

简单理解Linux的1和2操作

fd(file descriptor文件描述符)

在 shell 程式中,最常使用的大概有三个, 分别是:

  • 0 是一个文件描述符,表示标准输入(stdin) ,键盘输入,并返回在前端
  • 1 是一个文件描述符,表示标准输出(stdout),正确返回值 输出到前端
  • 2 是一个文件描述符,表示标准错误(stderr),错误返回值 输出到前端

示例

当前目录只有一个文件 a.txt.

[root@redhat box]# ls 
a.txt 
[root@redhat box]# ls a.txt b.txt 
ls: b.txt: No such file or directory 由于没有b.txt这个文件, 于是返回错误值, 这就是所谓的2输出 a.txt 而这个就是所谓的1输出

再接着看

[root@redhat box]# ls a.txt b.txt 1>file.out 2>file.err 
执行后,没有任何返回值. 原因是, 返回值都重定向到相应的文件中了,而不再前端显示 
[root@redhat box]# cat file.out 
a.txt 
[root@redhat box]# cat file.err 
ls: b.txt: No such file or directory 

总结

1> : 代表标准正确输出,即如果命令的执行结果是正确,则执行输出
2> : 代表标准错误输出,即如果命令的执行结果是错误,则执行输出
&>: 代表标准正确输出+标准错误输出

补充

一般来说, "1>" 通常可以省略成 ">".
即可以把如上命令写成: ls a.txt b.txt >file.out 2>file.err

2>&1

2>&1 错误返回值传递给1输出通道, 同样&1表示1输出通道.

[root@redhat box]# cat b.txt 1>file.out  2>&1 

假设b.txt不存在,那么正常来讲,这句命令并不会执行,但是在这里我们在后面加入了2>&1,将错误值传递给1输出通道
那么实际上这句话可等效为 cat b.txt 2>file.out
为什么我们要用这个东西而不直接使用2>呢?
有的时候我们并不知道文件存在与否,我们又不想将错误信息输出到屏幕上,这个时候使用2>&1就可以确保命令执行的成功性

&描述符

& 是一个描述符,如果1或2前不加&,会被当成一个普通文件。
1>&2 意思是把标准输出重定向到标准错误.
2>&1 意思是把标准错误输出重定向到标准输出。
&>filename 意思是把标准输出和标准错误输出都重定向到文件filename中

下面是来自百度知道的内容,大家可以参考下:

问:Linux重定向中 >&2 怎么理解?
问题补充:echo "aaaaaaaaaaaaaaaa" >&2 怎么理解?

答:
>&2 即 1>&2 也就是把结果输出到和标准错误一样;之前如果有定义标准错误重定向到某log文件,那么标准输出也重定向到这个log文件
如:ls 2>a1 >&2 (等同 ls >a1 2>&1)
把标准输出和标准错误都重定向到a1,终端上看不到任何信息。
其实也可以写成ls &>a1  根据情形而定


原文链接:https://blog.csdn.net/ck784101777/article/details/102974382

 

posted @ 2020-04-28 16:34  Wshile  阅读(389)  评论(0编辑  收藏  举报