1. 標准輸入,標准輸出與標准錯誤輸出
Linux下系統打開3個文件,標准輸入,標准輸出,標准錯誤輸出。
標准輸入:從鍵盤輸入數據,即從鍵盤讀入數據。
標准輸出:把數據輸出到終端上。
標准錯誤輸出:把標准錯誤輸出到終端上。
默認的標准輸入指的是鍵盤,默認的標准輸出與標准錯誤輸出指的是屏幕或者是終端。
系統為這三個文件分配了文件標識符fd(file descripter).
在Linux系統下,一切皆是文件,對文件的操作,一般要用到文件標識符。它們的文件標識符,分別為0,1,2.
2. 重定向
重定向分為輸入重定向與輸出重定向。
所謂的輸入重定向即輸入不從鍵盤讀入,而是從文件輸入或其它。
所謂的輸出重定向即不輸出到終端上,而是輸出到文件中去或其它。
""<"表示輸入重定向運算符,">"表示輸出重定向t運算符。
"<<"這種輸入告訴Shell,當前標准輸入來自命令行的一對分隔號的中間內容。
">>",用">"輸出時,如果文件不存在會自動建立一個文件,如果第二次輸入時,會覆蓋前一次的輸入內容,而">>"表示把第二次的輸出內容追加到文件中去,而不是覆蓋。
3. 下面看一下幾個例子
(1)輸入重定向
[root@localhost ~]# wc</etc/inittab
53 229 1666
wc統計行數,單詞數, 字符數
其中wc的輸入來自 /etc/inittab
[root@localhost ~]# wc <<aa
> 1
> 11
> 111
> aa
3 3 9
wc統計分隔符aa之間的內容。
(2)輸出重定向
[root@localhost ~]# ps -ef >a.txt //把進程的信息輸出重定向到a.txt文件中去
[root@localhost ~]# ps -ef> >a.txt //進程信息追加到a.txt的文件中去
其實,所謂的輸入輸出重定向就是不從鍵盤輸入和屏輸出。
4. Linux下輸出重定向的典型分析
(1) a.out > outfile 2>&1
(2) a.out 2> &1 >outfile
分析:
0代表標准輸入,1代表標准輸出,2代表標准錯誤輸出。其中1(即>=1>)可以省略,默認為標准輸出。
(1)首先把a.out重定向到outfile文件中去。然后把 2>&1把標准錯誤輸出重定向到標准輸出中去。此時的標准輸出已經重定向了,相當於把標准輸出與標准錯誤輸出都一起重定向到outfile中去。 &1代表的是標准輸出的文件描述符。1一般放在左邊表示標准輸出重定向到什么位置,而1放在右邊是重定向到標准輸出中,所以用&區分一下,表示標准輸出的文件描述符。2>1表示把標准錯誤重定向到文件1中去,2>&1則表示標准錯誤重定向到標准輸出中去。
(2)首先把標准錯誤輸出重定向到標准輸出中,此時標准輸出還在終端。因此標准錯誤也在終端。然后標准輸出到outfile中去了。而標准錯誤還是在終端。
因此,(1)表示標准輸出與標准錯誤都到outfile中去了。
(2)表示標准輸出到outfile,但標准錯誤輸出仍然在終端。
ls 1>/dev/null 2>/dev/null
ls >/dev/null 2>&1
/dev/null是一個垃圾箱,是一個無底洞,表示的含義為不顯示。
即標准輸出與標准錯誤輸出不顯示。
以上兩個命令表示的含義是相同的。
以上是關於Linux下的重定向問題,一定要深刻理解原理。
原文地址:http://blog.csdn.net/jfkidear/article/details/7823486