zoukankan      html  css  js  c++  java
  • shell 重定向

    test.sh > filename 重定向test.sh的输出到文件 filename 中。如果 filename 存在的话,那么将会被覆盖。

    test.sh &> filename 重定向 test.sh 的 stdout(标准输出)和 stderr(标准错误)到 filename 中。

    test.sh >&2 重定向 test.sh 的 stdout 到 stderr 中。

    test.sh >> filename 把 test.sh 的输出追加到文件 filename 中。如果filename 不存在的话,将会被创建。

    shell上:
    0表示标准输入
    1表示标准输出
    2表示标准错误输出
    > 默认为标准输出重定向,与 1> 相同
    2>&1 意思是把 标准错误输出 重定向到 标准输出.
    &>file 意思是把 标准输出 和 标准错误输出 都重定向到文件file中

     

    用例子说话:


    1. grep da * 1>&2 
    2. rm -f $(find / -name core) &> /dev/null
    上面两例中的 & 如何理解,&不是放到后台执行吗?

    牛解:

    1.&>file或n>&m均是一个独立的重定向符号,不要分开来理解。

    2.明确文件和文件描述符的区别。

    3.&>file表示重定向标准输出和错误到文件
    例如:
    rm -f $(find / -name core) &> /dev/null,/dev/null是一个文件,这个文件比较特殊,所有传给它的东西它都丢弃掉。

    4.n>&m表示使文件描述符n成为输出文件描述符m的副本。这样做的好处是,有的时候你查找文件的时候很容易产生无用的信息,如:2> /dev/null的作用就是不显示标准错误输出;另外当你运行某些命令的时候,出错信息也许很重要,便于你检查是哪出了毛病,如:2>&1
    例如:
    注意,为了方便理解,必须设置一个环境使得执行grep da *命令会有正常输出和错误输出,然后分别使用下面的命令生成三个文件:
    grep da * > greplog1
    grep da * > greplog2 1>&2   
    grep da * > greplog3 2>&1  //grep da * 2> greplog4 1>&2 结果一样
    #查看greplog1会发现里面只有正常输出内容
    #查看greplog2会发现里面什么都没有

    #查看greplog3会发现里面既有正常输出内容又有错误输出内容

  • 相关阅读:
    [转] 程序集和Dll的区别
    [转载] 节选自:2005年件我的第一次软件行业创业,烧掉30万、2年时间打水漂的惨痛教训总结
    [分享]屏幕取色工具
    LINQ学习笔记
    XP系统 mscorsvw.exe进程 占CPU资源 开机加载网络连接很慢 解决方法
    [原创] ASP.NET中事件执行顺序
    CHARINDEX, INSTR
    [转载]如何为自己的网站设置二级域名?
    [转载] System.Threading.Timer类的TimerCallback 委托
    [转载]ASP.NET 2.0 页面事件执行顺序
  • 原文地址:https://www.cnblogs.com/alansheng/p/5395273.html
Copyright © 2011-2022 走看看