也就是把结果输出到和标准错误一样;之前如果有定义标准错误重定向到某file文件,那么标准输出也重定向到这个file文件。
    其中&的意思,可以看成是“The same as”、“与…一样”的意思

    shell上:
    0表示标准输入
    1表示标准输出
    2表示标准错误输出

    • (默认)为标准输出重定向,与 1> 相同

    • 1>file 把标准输出重定向到文件file中
    • 2>file 把标准错误输出重定向到文件file中
    • &>file 意思是把 标准输出 和 标准错误输出 都重定向到文件file中
    • 2>&1 意思是把 标准错误输出 重定向到 标准输出
      用例子说话:

    例如:
    设置一个环境使得执行grep da *命令会有正常输出和错误输出,然后分别使用下面的命令生成四个文件:

    1. grep da * > greplog1
    2. 标准输出重定向到greplog1文件,所以greplog1里是正常输出内容
    3. grep da * > greplog2 1>&2
    4. 标准输出重定向到标准错误输出,所以greplog2里没有内容
    5. grep da * > greplog3 2>&1
    6. 标准错误输出重定向到标准输出,所以greplog2里既有正常输出内容又有错误输出内容
    7. grep da * 2> greplog4 1>&2
    8. 结果同上,只是步骤相反

    牛解:

    1. &>file或n>&m均是一个独立的重定向符号,不要分开来理解。
    2. 明确文件和文件描述符的区别。
    3. &>file表示重定向标准输出和错误到文件
      例如:
      rm -f $(find / -name core) &> /dev/null,/dev/null是一个文件,这个文件比较特殊,所有传给它的东西它都丢弃掉。这样做的好处是,有的时候你查找文件的时候很容易产生无用的信息,如:2> /dev/null的作用就是不显示标准错误输出
    4. n>&m表示使文件描述符n成为输出文件描述符m的副本。当你运行某些命令的时候,出错信息也许很重要,便于你检查是哪出了毛病,如:2>&1