Standard streams (標(biāo)準(zhǔn)流) 介紹

實(shí)際場(chǎng)景

  1. 在操作Linux命令行的時(shí)候蛮拔,如果需要將日志到處并保存到某個(gè)文件,我們可能會(huì)用到命令 2>&1晃财,將“正常日志”和“錯(cuò)誤日志”都放在一起叨橱。
  2. 在寫Java應(yīng)用時(shí),我們經(jīng)常會(huì)用到 System.out.println(.....) 來打印程序運(yùn)行時(shí)的一些信息断盛,實(shí)際上Java還提供了 System.err.println(.....) 方法用來打印程序出錯(cuò)時(shí)候的信息罗洗。

介紹

在Unix系統(tǒng)及類Unix系統(tǒng)中,Standard streams(標(biāo)準(zhǔn)流)是計(jì)算機(jī)程序與其環(huán)境之間钢猛,信息輸入和輸出的通道栖博。包括stdin,stdout和stderr.
根據(jù)POSIX協(xié)議厢洞,這3個(gè)標(biāo)準(zhǔn)流都有自己對(duì)應(yīng)的文件描述符(File_descriptor)

文件描述符(整數(shù)值) 名稱 <unistd.h>符號(hào)常量 <stdio.h>文件流
0 Standard input STDIN_FILENO stdin
1 Standard output STDOUT_FILENO stdout
2 Standard error STDERR_FILENO stderr
Standard Streams

起源

a. 標(biāo)準(zhǔn)流(Standard streams)的起源

在Unix之前的操作系統(tǒng)仇让,程序必須明確指出鏈接到合適的輸入和輸出數(shù)據(jù)。對(duì)這當(dāng)中的許多系統(tǒng)而言躺翻,這牽涉一些錯(cuò)綜復(fù)雜而又與特定操作系統(tǒng)相關(guān)的事丧叽,過程相當(dāng)復(fù)雜(如控制環(huán)境設(shè)置、訪問一個(gè)文件表格公你、決定區(qū)域數(shù)據(jù)集踊淳、和決定讀卡器、磁帶、磁盤迂尝、打印機(jī)脱茉、打卡機(jī)或交互式終端機(jī))。

Unix 的偉大開創(chuàng)貢獻(xiàn)之一垄开,就是是提供 抽象設(shè)備 :它免除了程序須要知道或在意它正與哪個(gè)設(shè)備溝通琴许。 Unix 借由數(shù)據(jù)流的概念來消除這種復(fù)雜。數(shù)據(jù)流是指一種數(shù)據(jù)字節(jié)的有序序列溉躲,在其讀到文件結(jié)尾(End of file, EOF)之前可以一直被讀取榜田。另一個(gè) Unix 突破為默認(rèn)自動(dòng)鏈接輸入和輸出,程序(或者說編寫它的程序員)锻梳,不用為了文件的輸入箭券、輸出操心。在此之前疑枯,程序員需要用復(fù)雜的工作控制語言創(chuàng)建鏈接辩块,協(xié)調(diào)責(zé)任。

b. 文件描述符(File_descriptor)的起源

linux為了實(shí)現(xiàn)一切皆文件的設(shè)計(jì)哲學(xué)荆永,不僅將數(shù)據(jù)抽象成了文件废亭,也將一切操作和資源抽象成了文件,比如說硬件設(shè)備屁魏,socket滔以,磁盤捉腥,進(jìn)程氓拼,線程等。這樣的設(shè)計(jì)將系統(tǒng)的所有動(dòng)作都統(tǒng)一起來抵碟,實(shí)現(xiàn)了對(duì)系統(tǒng)的原子化操作桃漾,大大降低了維護(hù)和操作的難度,想想看拟逮,對(duì)于socket撬统,硬件設(shè)備,我們只要讀讀寫寫文件就能對(duì)其進(jìn)行操作是多么爽的一件事敦迄。

那么在操作這些所謂的文件的時(shí)候恋追,我們不可能沒操作一次就要找一次名字吧,這樣會(huì)耗費(fèi)大量的時(shí)間和效率罚屋。咱們可以每一個(gè)文件操作一個(gè)索引苦囱,這樣,要操作文件的時(shí)候脾猛,我們直接找到索引就可以對(duì)其進(jìn)行操作了撕彤。我們將這個(gè)索引叫做文件描述符(file descriptor),在系統(tǒng)里面是一個(gè)非負(fù)的整數(shù)猛拴。每打開或創(chuàng)建一個(gè)文件羹铅,內(nèi)核就會(huì)向進(jìn)程返回一個(gè)fd蚀狰,第一個(gè)打開文件是0,第二個(gè)是1职员,依次遞增麻蹋。

Linux的根目錄/dev是 Device(設(shè)備)的縮寫。該目錄下存放的是 Linux 的外部設(shè)備廉邑,在 Linux 中訪問設(shè)備的方式和訪問文件的方式是相同的哥蔚。從該目錄下的內(nèi)容也可以看到標(biāo)準(zhǔn)流的影子

$ ll /dev |grep std
lrwxrwxrwx   1 root root          15 Jul 27 16:54 stderr -> /proc/self/fd/2
lrwxrwxrwx   1 root root          15 Jul 27 16:54 stdin -> /proc/self/fd/0
lrwxrwxrwx   1 root root          15 Jul 27 16:54 stdout -> /proc/self/fd/1    
$ # Linux的文件描述符可以通過 /proc/PID/fd/ 路徑獲取使用。

應(yīng)用

  1. Linux命令行中蛛蒙,可以通過重定向符號(hào)(例如:>)來控制標(biāo)準(zhǔn)流的輸出糙箍,使用實(shí)例。
  2. Java應(yīng)用當(dāng)中牵祟,也可以通過java.lang.Process類來讀取/寫入標(biāo)準(zhǔn)流深夯,可參考源碼方法注釋

Ref:

  1. https://en.wikipedia.org/wiki/Standard_streams
  2. http://www.reibang.com/p/504a53c30c17
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末诺苹,一起剝皮案震驚了整個(gè)濱河市咕晋,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌收奔,老刑警劉巖掌呜,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異坪哄,居然都是意外死亡质蕉,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門翩肌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來模暗,“玉大人,你說我怎么就攤上這事念祭《矣睿” “怎么了?”我有些...
    開封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵粱坤,是天一觀的道長隶糕。 經(jīng)常有香客問我,道長站玄,這世上最難降的妖魔是什么枚驻? 我笑而不...
    開封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮蜒什,結(jié)果婚禮上测秸,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好霎冯,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開白布铃拇。 她就那樣靜靜地躺著,像睡著了一般沈撞。 火紅的嫁衣襯著肌膚如雪慷荔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天缠俺,我揣著相機(jī)與錄音显晶,去河邊找鬼。 笑死壹士,一個(gè)胖子當(dāng)著我的面吹牛磷雇,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播躏救,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼唯笙,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了盒使?” 一聲冷哼從身側(cè)響起崩掘,我...
    開封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎少办,沒想到半個(gè)月后苞慢,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡英妓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年挽放,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鞋拟。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡骂维,死狀恐怖惹资,靈堂內(nèi)的尸體忽然破棺而出贺纲,到底是詐尸還是另有隱情,我是刑警寧澤褪测,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布猴誊,位于F島的核電站,受9級(jí)特大地震影響侮措,放射性物質(zhì)發(fā)生泄漏懈叹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一分扎、第九天 我趴在偏房一處隱蔽的房頂上張望澄成。 院中可真熱鬧,春花似錦、人聲如沸墨状。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽肾砂。三九已至列赎,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間镐确,已是汗流浹背包吝。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留源葫,地道東北人诗越。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像息堂,于是被迫代替她去往敵國和親掺喻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容

  • 官網(wǎng) 中文版本 好的網(wǎng)站 Content-type: text/htmlBASH Section: User ...
    不排版閱讀 4,378評(píng)論 0 5
  • 一储矩、Python簡(jiǎn)介和環(huán)境搭建以及pip的安裝 4課時(shí)實(shí)驗(yàn)課主要內(nèi)容 【Python簡(jiǎn)介】: Python 是一個(gè)...
    _小老虎_閱讀 5,734評(píng)論 0 10
  • 為何叫做 shell 感耙? shell prompt(PS1) 與 Carriage Return(CR) 的關(guān)系?...
    Zero___閱讀 3,142評(píng)論 3 49
  • 網(wǎng)絡(luò)編程 一.楔子 你現(xiàn)在已經(jīng)學(xué)會(huì)了寫python代碼,假如你寫了兩個(gè)python文件a.py和b.py屡拨,分別去運(yùn)...
    go以恒閱讀 1,999評(píng)論 0 6
  • python中的subprocess.Popen()使用 從python2.4版本開始,可以用subprocess...
    其實(shí)我很dou閱讀 17,504評(píng)論 0 1