也就是把结果输出到和标准错误一样;之前如果有定义标准错误重定向到某file文件,那么标准输出也重定向到这个file文件。
其中&的意思,可以看成是“The same as”、“与…一样”的意思
shell上:
0表示标准输入
1表示标准输出
2表示标准错误输出
(默认)为标准输出重定向,与 1> 相同
- 1>file 把标准输出重定向到文件file中
- 2>file 把标准错误输出重定向到文件file中
- &>file 意思是把 标准输出 和 标准错误输出 都重定向到文件file中
- 2>&1 意思是把 标准错误输出 重定向到 标准输出
用例子说话:
例如:
设置一个环境使得执行grep da *命令会有正常输出和错误输出,然后分别使用下面的命令生成四个文件:
grep da * > greplog1
标准输出重定向到greplog1文件,所以greplog1里是正常输出内容
grep da * > greplog2 1>&2
标准输出重定向到标准错误输出,所以greplog2里没有内容
grep da * > greplog3 2>&1
标准错误输出重定向到标准输出,所以greplog2里既有正常输出内容又有错误输出内容
grep da * 2> greplog4 1>&2
结果同上,只是步骤相反
牛解:
- &>file或n>&m均是一个独立的重定向符号,不要分开来理解。
- 明确文件和文件描述符的区别。
- &>file表示重定向标准输出和错误到文件
例如:rm -f $(find / -name core) &> /dev/null
,/dev/null是一个文件,这个文件比较特殊,所有传给它的东西它都丢弃掉。这样做的好处是,有的时候你查找文件的时候很容易产生无用的信息,如:2> /dev/null的作用就是不显示标准错误输出 - n>&m表示使文件描述符n成为输出文件描述符m的副本。当你运行某些命令的时候,出错信息也许很重要,便于你检查是哪出了毛病,如:2>&1