/*********************************************************************
* Author : Samson
* Date : 08/18/2012
* Test platform:
* GNU Linux version 2.6.29.4
* GNU bash, version 4.0.16(1)-release (i386-redhat-linux-gnu)
* *******************************************************************/
在上一篇關於shell編程的例子中,有講到把shell指令碼進行擴充之後重新導向到一個檔案中,以便進行查看和調試
http://blog.csdn.net/yygydjkthh/article/details/7879690 。但是,若是有另一種情況:只是在某些地方進行重新導向,而其他地方不進行重新導向。那麼我們就來修改一下上一篇中的例子來進行這種需求的滿足:
#!/bin/bash
function setlogfile
{
if ! [ -z "$1" ]; then
echo "logfilename is not empty!" >> kthh
exec 3>&1
exec 4>&2
exec 2>> $1
exec 1>> $1
fi
}
num1=$1
logfile=$2
execlogfile=$3
setlogfile ${execlogfile}
set -x
if [ $num1 -eq 0 ]; then
echo "num1 is 0">> ${logfile}
elif [ $num1 -ge 0 ]; then
echo "num1 is grate 0">> ${logfile}
else
echo "num1 is less 0">> ${logfile}
fi
exec 2>&4
exec 1>&3
if [ $num1 -eq 0 ]; then
echo "num1 is 0 again">> ${logfile}
fi
在函數setlogfile中添加了exec 3>&1;exec 4>&2這兩句,而其中,3、1、4、2都是表示檔案描述符,1是標準輸出,也即是STDOUT,2是標準錯誤輸出,即是STDERR,1和2本來是輸出在顯示器上的,而3、4是表示兩個檔案描述符,可理解成是兩個儲存1和2的臨時變數, 3>&1表示把檔案描述符1的賦值給檔案描述符3,也可以理解為是把檔案描述符1(當前標準輸出)的規則儲存到了檔案描述符3中,這時再把1的輸出重新導向到檔案中,在下面的shell程式中,我們又使用了1>&3這就表示是把儲存在檔案描述符3中的原標準輸出的規則重新賦值給檔案描述符1,原來標準輸出的規則是輸出到顯示器上,而不是輸出到一個檔案中。這就是整個重新導向和取消重新導向還原的過程。2和4也是一樣的道理。
閑話少說,先看運行結果:
[root@UFO shellprogram]# ./testexecutelog.sh 0 msglog execlog
+ exec
+ '[' 0 -eq 0 ']'
+ echo 'num1 is 0 again'
[root@UFO shellprogram]# cat execlog
+ '[' 0 -eq 0 ']'
+ echo 'num1 is 0'
+ exec
看到結果了嗎??? 沒看到嗎??? 那就仔細看了,^_^