• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            大龍的博客

            常用鏈接

            統計

            最新評論

            詳解重定向1>&2和2>&1

            大家在剛開始學SHELL的時候,可能對1>&2和2>&1,&2,是什么意思可能不是很清楚,下面的文章希望對大家有幫助

            說到 I/O redirection ,讓我們先來認識一下 File Descriptor (FD) 。 

            程式的咚悖詿蟛糠萸闆r下都是進行數據(data)的處理, 
            這些數據從哪讀進?又,送出到哪裡呢? 
            這就是 file descriptor (FD) 的功用了。 

            在 shell 程式中,最常使用的 FD 大概有三個,分別為: 
            0: Standard Input (STDIN) 
            1: Standard Output (STDOUT) 
            2: Standard Error Output (STDERR) 

            在標準情況下,這些 FD 分別跟如下設備(device)關聯: 
            stdin(0): keyboard 
            stdout(1): monitor 
            stderr(2): monitor 


            * 1>; 
            * 2>; 
            前者是改變 stdout 的數據輸出通道,後者是改變 stderr 的數據輸出通道。 
            兩者都是將原本要送出到 monitor 的數據轉向輸出到指定檔案去。 
            由於 1 是 >; 的預設值,因此,1>; 與 >; 是相同的,都是改 stdout 。 

            用上次的 ls 例子來說明一下好了:

            $ ls my.file no.such.file 1>;file.out 
            ls: no.such.file: No such file or directory
            這樣 monitor 就只剩下 stderr 而已。因為 stdout 給寫進 file.out 去了。

            $ ls my.file no.such.file 2>;file.err 
            my.file
            這樣 monitor 就只剩下 stdout ,因為 stderr 寫進了 file.err 。

            $ ls my.file no.such.file 1>;file.out 2>;file.err
            這樣 monitor 就啥也沒有,因為 stdout 與 stderr 都給轉到檔案去了... 

            呵~~~ 看來要理解 >; 一點也不難啦﹗是不?沒騙你吧? ^_^ 
            不過,有些地方還是要注意一下的。 
            首先,是 file locking 的問題。比方如下這個例子:

            $ ls my.file no.such.file 1>;file.both 2>;file.both
            從 file system 的角度來說,單一檔案在單一時間內,只能被單一的 FD 作寫入。 
            假如 stdout(1) 與 stderr(2) 都同時在寫入 file.both 的話, 
            則要看它們在寫入時否碰到同時競爭的情形了,基本上是"先搶先贏"的原則。 
            讓我們用周星馳式的"慢鏡頭"來看一下 stdout 與 stderr 同時寫入 file.out 的情形好了: 
            * 第 1, 2, 3 秒為 stdout 寫入 
            * 第 3, 4, 5 秒為 stderr 寫入 
            那麼,這時候 stderr 的第 3 秒所寫的數據就丟失掉了﹗ 
            要是我們能控制 stderr 必須等 stdout 寫完再寫,或倒過來,stdout 等 stderr 寫完再寫,那問題就能解決。 
            但從技術上,較難掌控的,尤其是 FD 在作"長期性"的寫入時... 

            那,如何解決呢?所謂山不轉路轉、路不轉人轉嘛, 
            我們可以換一個思維:將 stderr 導進 stdout 或將 stdout 導進 sterr ,而不是大家在搶同一份檔案,不就行了﹗ 
            bingo﹗就是這樣啦: 
            * 2>;&1 就是將 stderr 併進 stdout 作輸出 
            * 1>;&2 或 >;&2 就是將 stdout 併進 stderr 作輸出 
            於是,前面的錯誤操作可以改為:

            $ ls my.file no.such.file 1>;file.both 2>;&1 
            或 
            $ ls my.file no.such.file 2>;file.both >;&2

            posted on 2011-01-02 00:49 大龍 閱讀(557) 評論(0)  編輯 收藏 引用

            久久久av波多野一区二区| 久久电影网2021| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 欧美精品一本久久男人的天堂| 久久不射电影网| 日韩AV毛片精品久久久| 奇米影视7777久久精品| 精品久久久久久无码人妻蜜桃| 亚洲另类欧美综合久久图片区| 精品久久久久久中文字幕人妻最新| 久久WWW免费人成—看片| 久久久无码精品亚洲日韩按摩 | 日韩精品久久久肉伦网站| 国产精品久久久久一区二区三区 | 久久99热这里只频精品6| 久久久精品一区二区三区| 噜噜噜色噜噜噜久久| 久久久精品日本一区二区三区| 久久天天躁狠狠躁夜夜avapp| 亚洲天堂久久久| 日本高清无卡码一区二区久久 | 99久久国产亚洲高清观看2024| 国产69精品久久久久久人妻精品| 国产午夜精品理论片久久| 久久91精品国产91久久小草| 婷婷五月深深久久精品| 国产69精品久久久久久人妻精品| 亚洲Av无码国产情品久久| 久久精品国产99久久丝袜| 狠狠精品久久久无码中文字幕 | 狠狠干狠狠久久| 久久青青草原精品影院| 久久精品国产亚洲AV香蕉| 久久精品国产亚洲AV麻豆网站 | 少妇高潮惨叫久久久久久| 2020国产成人久久精品| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久精品国产第一区二区三区| 午夜久久久久久禁播电影| 国产精品免费福利久久| 久久久国产精品网站|