Linux | 深入理解 2 &1的含义 及 后面的 &

A.首先了解下1和2在Linux中代表什么

在Linux系统中0 1 2是一个文件描述符

名称代码操作符Linux 下文件描述符(Debian 为例)


Linux | 深入理解 2 &1的含义 及 后面的 &_第1张图片
image.png

从上表看的出来,我们平时使用的

echo "hello" > t.log

(将“hello"标准输出到 t.log 文件)

其实也可以写成

echo "hello" 1> t.log

B.关于2>&1的含义

(关于输入/输出重定向本文就不细说了,不懂的可以参考这里,主要是要了解> < << >> <& >& 这6个符号的使用)

1、含义:将标准错误输出重定向到标准输出

2、符号>&是一个整体,不可分开,分开后就不是上述含义了。

比如有些人可能会这么想:2是标准错误输入,1是标准输出,>是重定向符号,那么"将标准错误输出重定向到标准输出"是不是就应该写成"2>1"就行了?是这样吗?

如果是尝试过,你就知道2>1的写法其实是将标准错误输出重定向到名为"1"的文件里去了

3、写成2&>1也是不可以的

C.为什么2>&1要放在后面

考虑如下一条shell命令

ls / /aabb >log 2>&1 &

为什么2>&1一定要写到>log后面,才表示标准错误输出和标准输出都定向到log中?

我们不妨把1和2都理解是一个指针,然后来看上面的语句就是这样的:

本来1----->屏幕 (1指向屏幕)
执行>log后, 1----->log (1指向log)
执行2>&1后, 2----->1 (2指向1,而1指向log,因此2也指向了log)

最后一个&表示把条命令放到后台执行

我来举一个简单的例子,看看如何使用 & 号将下面这个命令放到后台运行:

cp -R original/dir/ backup/dir/

这个命令的目的是将 original/dir/ 的内容递归地复制到 backup/dir/ 中。虽然看起来很简单,但是如果原目录里面的文件太大,在执行过程中终端就会一直被卡住。

所以,可以在命令的末尾加上一个&号,将这个任务放到后台去执行:

cp -R original/dir/ backup/dir/ &

任务被放到后台执行之后,就可以立即继续在同一个终端上工作了,甚至关闭终端也不影响这个任务的正常执行。

再来分析下

ls / /aabb  2>&1 >log &

本来1----->屏幕 (1指向屏幕)
执行2>&1后, 2----->1 (2指向1,而1指向屏幕,因此2也指向了屏幕)
执行>log后, 1----->log (1指向log,2还是指向屏幕)
所以这就不是我们想要的结果。

简单做个试验测试下上面的想法:

代码如下:

ls / /aabb

显示结果:

ls: cannot access /aabb: No such file or directory

/:

123  boot    etc        lib        lp    opt  run  sys  var

aaa  czw1801  hello sxt  lib64      media  proc  sbin  tmp

bin  dev      home      lost+found  mnt    root  srv  usr

分别有 错误输出 和 标准输出

运行下面指令:

ls / /aabb  2>&1 >log &

正确应为:ls / /aabb >log 2>&1 &

按Enter退回终端,cat log 查阅


Linux | 深入理解 2 &1的含义 及 后面的 &_第2张图片
image.png

会看到只输出了 ls / 的内容,未输出 / aabb的内容

D.每次都写">log 2>&1"太麻烦,能简写吗?

有以下两种简写方式

&>log

>&log

比如上面小节中的写法就可以简写为:

ls / /aabb &>log &

上面两种方式都和">log 2>&1"一个语义。

那么 上面两种方式中&>和>&有区别吗?

语义上是没有任何区别的,但是第一中方式是最佳选择,一般使用第一种

你可能感兴趣的:(Linux | 深入理解 2 &1的含义 及 后面的 &)