我们将直接通过几个例子来讲解。
grep abc test.txt 1>&2 rm -f $(find / -name test) &> /dev/null
上面两例中的 & 如何理解,& 不是放到后台执行吗?
案例分析:
1.&>file 或 n>&m 均是一个独立的重定向符号,不要分开来理解。
2.明确文件和文件描述符的区别。
3.&>file 表示重定向标准输出和错误到文件,例如:
rm -f $(find / -name test) &> /dev/null
/dev/null 是一个文件,这个文件比较特殊,所有传给它的东西它都丢弃掉。
4.n>&m 表示使文件描述符 n 成为输出文件描述符 m 的副本。这样做的好处是,有的时候你查找文件的时候很容易产生无用的信息,如:2 > /dev/null 的作用就是不显示标准错误输出;另外当你运行某些命令的时候,出错信息也许很重要,便于你检查是哪出了毛病,如:2>&1。
更多例子:
注意,为了方便理解,必须设置一个环境使得执行 grep abc test.txt 命令会有正常输出和错误输出,然后分别使用下面的命令生成三个文件:
grep abc test.txt > log1 grep abc test.txt > log2 1>&2 grep abc test.txt > log3 2>&1 #grep abc test.txt 2>log4 1>&2 结果一样
1.查看 log1 会发现里面只有正常输出内容?
2.查看 log2 会发现里面什么都没有?