-----------------------------------------------------------------------------------
把/dev/null看作"黑洞". 它非常等价于一个只写文件. 所有写入它的内容都会永远丢失. 而尝试从它那儿读取内容则什么也读不到. 然而,/dev/null对命令行和脚本都非常的有用.
禁止标准输出.
1 cat $filename >/dev/null 2 # 文件内容丢失,而不会输出到标准输出. |
禁止标准错误
1 rm $badname 2>/dev/null 2 # 这样错误信息[标准错误]就被丢到太平洋去了. |
禁止标准输出和标准错误的输出.
1 cat $filename 2>/dev/null >/dev/null 2 # 如果"$filename"不存在,将不会有任何错误信息提示. 3 # 如果"$filename"存在, 文件的内容不会打印到标准输出. 4 # 因此Therefore, 上面的代码根本不会输出任何信息. 5 # 当只想测试命令的退出码而不想有任何输出时非常有用。 6 #-----------测试命令的退出 begin ----------------------# 7 # ls dddd 2>/dev/null 8 8 # echo $? //输出命令退出代码:0为命令正常执行,1-255为有出错。 9 #-----------测试命令的退出 end-----------# 10# cat $filename &>/dev/null 11 # 也可以, 由 Baris Cicek 指出.
有的时候你查找文件的时候很容易产生无用的信息,如:2> /dev/null的作用就是不显示标准错误输出;另外当你运行某些命令的时候,出错信息也许很重要,便于你检查是哪出了毛病,如:2>&1
----------------------------------------------------------------
实用总结
如果在编译代码的时候想看全部log,在输出的终端上找是非常不方便的,在编译完源码后想看编译时输出的log,最好的方法就是让所有输出(标准输出1和标准错误输出2)都存储在mybuild.log里。
为此可以这样实现:
./build.sh 2>&1 | tee mybuild.log ##tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。
这样我们既可以在终端实时查看当前的编译log,有可以讲屏幕上的输出重定向到mybuild.log文件当中。
----------------------------------------------------------------
若不了解tee命令,想了解tee命令请看如下说明:
linux tee 命令详解
功能说明:读取标准输入的数据,并将其内容输出成文件。
语 法:tee [-ai][--help][--version][文件...]
补充说明:tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。
参 数:
-a或--append 附加到既有文件的后面,而非覆盖它.
-i-i或--ignore-interrupts 忽略中断信号。
--help 在线帮助。
--version 显示版本信息。
若不了解tee命令,想了解tee命令请看如下说明:
linux tee 命令详解
功能说明:读取标准输入的数据,并将其内容输出成文件。
语 法:tee [-ai][--help][--version][文件...]
补充说明:tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。
参 数:
-a或--append 附加到既有文件的后面,而非覆盖它.
-i-i或--ignore-interrupts 忽略中断信号。
--help 在线帮助。
--version 显示版本信息。
root pts/0 2009-02-17 07:47 (123.123.123.123)
[root@localhost ~]# cat who.out
root pts/0 2009-02-17 07:47 (123.123.123.123)
[root@localhost ~]# pwd | tee -a who.out
/root
[root@localhost ~]# cat who.out
root pts/0 2009-02-17 07:47 (123.123.123.123)
/root
[root@localhost ~]#