node_03 基本模塊

\color{orange}{stream}
Node.js提供的又一個僅在服務(wù)區(qū)端可用的模塊帖汞,目的是支持“流”這種數(shù)據(jù)結(jié)構(gòu)。
從文件流\color{purple}{讀取}文本內(nèi)容的示例

createReadStream

\color{red}{腳本}(index13.js)

    'use strit'

    var fs = require('fs');
    //打開一個流
    var rs  = fs.createReadStream('text.text','utf-8');

    rs.on('data',function(chunk){
        console.log('DATA:')
        console.log(chunk)
    })

    rs.on('end',function(){
        console.log('End')
    })

    rs.on('error',function(err){
        console.log('ERROR'+err)
    })

\color{red}{腳本}(text.text)

使用Stream寫入二進制數(shù)據(jù)
index4.png

要注意,data事件可能會有多次芍躏,每次傳遞的chunk是流的一部分數(shù)據(jù)。


createWriteStream

要以流的形式\color{purple}{寫入}文件,只需要不斷調(diào)用write()方法定庵,最后以end()結(jié)束:

    'use strict';

    var fs = require('fs');

    var ws1 = fs.createWriteStream('text.text', 'utf-8');

    ws1.write('使用Stream寫入文本數(shù)據(jù)...\n');
    ws1.write('END.');
    ws1.write('END.');
    ws1.end();

\color{red}{腳本}(text.text)直接被改寫為:

index4.png


例子2:

    'use strict';

    var fs = require('fs');

    var ws1 = fs.createWriteStream('text.text', 'utf-8');

    ws1.write('使用Stream寫入文本數(shù)據(jù)...\n');
    ws1.write('END.');
    ws1.write('123456789.');
    ws1.end();

    var ws2 = fs.createWriteStream('text.text');
    ws2.write(new Buffer('使用Stream寫入文本數(shù)據(jù)','utf-8'));
    ws2.write(new Buffer('...\nggg','utf-8'))
    ws2.write(new Buffer('1','utf-8'))
    ws2.end()

\color{red}{腳本}(text.text)直接被改寫為:

index4.png

ws1每個字符串都被ws2得對應(yīng)長度的字符串一一所,沒有被覆蓋的直接輸出;
可以在ws1一開始定義'utf-8',也可以在輸出的時候加上'utf-8'.


例子3:

    'use strict';

    var fs = require('fs');

    var ws1 = fs.createWriteStream('text.text', 'utf-8');

    ws1.write('使用Stream寫入文本數(shù)據(jù)...\n');
    ws1.write('END.');
    ws1.write('123456789.');
    ws1.end();

    var ws2 = fs.createWriteStream('text.text');
    ws2.write(new Buffer('使用Stream寫入文本數(shù)據(jù)','utf-8'));
    ws2.write(new Buffer('...**ggg','utf-8'))
    ws2.write(new Buffer('1','utf-8'))
    ws2.end()
index4.png

轉(zhuǎn)譯符也被當做2個字節(jié)看待踪危。

所有可以讀取數(shù)據(jù)的流都繼承自stream.Readable蔬浙,所有可以寫入的流都繼承自stream.Writable。


pipe

就像可以把兩個水管串成一個更長的水管一樣贞远,兩個流也可以串起來畴博。一個Readable流和一個Writable流串起來后,所有的數(shù)據(jù)自動從Readable流進入Writable流蓝仲,這種操作叫pipe俱病。

在Node.js中,Readable流有一個pipe()方法袱结,就是用來干這件事的庶艾。

讓我們用pipe()把一個文件流和另一個文件流串起來,這樣源文件的所有數(shù)據(jù)就自動寫入到目標文件里了擎勘,所以咱揍,這實際上是一個復(fù)制文件的程序:

\color{red}{腳本}(index15.js)

    'use strict'

    var fs = require('fs');
    var rs = fs.createReadStream('node.text')
    var ws = fs.createWriteStream('text.text')
    rs.pipe(ws)

\color{red}{腳本}(node.text')

我是node

\color{red}{腳本}(text.text')

使用Stream寫入文本數(shù)據(jù)...**ggg123456789.

\color{red}{運行後} \color{purple}{腳本}(text.text'):

我是node

如果pipe\color{purple}{存在}的文件,文件內(nèi)容直接被重寫棚饵,而pipe\color{purple}{不存在}的文件煤裙,則在createWriteStream的路徑下新建一個createReadStream路徑一樣的文件。


默認情況下噪漾,當Readable流的數(shù)據(jù)讀取完畢硼砰,end事件觸發(fā)后,將自動關(guān)閉Writable流欣硼。如果我們不希望自動關(guān)閉Writable流题翰,需要傳入?yún)?shù):(剛?cè)腴T並不是很了解這個實際用途,先筆記下來,有大神的可以回復(fù)一下豹障,Thx)
readable.pipe(writable, { end: false });

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末冯事,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子血公,更是在濱河造成了極大的恐慌昵仅,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件累魔,死亡現(xiàn)場離奇詭異摔笤,居然都是意外死亡,警方通過查閱死者的電腦和手機垦写,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進店門吕世,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人梯投,你說我怎么就攤上這事命辖。” “怎么了晚伙?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長俭茧。 經(jīng)常有香客問我咆疗,道長,這世上最難降的妖魔是什么母债? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任午磁,我火速辦了婚禮,結(jié)果婚禮上毡们,老公的妹妹穿的比我還像新娘迅皇。我一直安慰自己,他們只是感情好衙熔,可當我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布登颓。 她就那樣靜靜地躺著,像睡著了一般红氯。 火紅的嫁衣襯著肌膚如雪框咙。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天痢甘,我揣著相機與錄音喇嘱,去河邊找鬼。 笑死塞栅,一個胖子當著我的面吹牛者铜,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼作烟,長吁一口氣:“原來是場噩夢啊……” “哼愉粤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起俗壹,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤科汗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后绷雏,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體头滔,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年涎显,在試婚紗的時候發(fā)現(xiàn)自己被綠了坤检。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡期吓,死狀恐怖早歇,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情讨勤,我是刑警寧澤箭跳,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站潭千,受9級特大地震影響谱姓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜刨晴,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一屉来、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧狈癞,春花似錦茄靠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至真竖,卻和暖如春儡蔓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背疼邀。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工喂江, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人旁振。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓获询,卻偏偏與公主長得像涨岁,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子吉嚣,可洞房花燭夜當晚...
    茶點故事閱讀 45,055評論 2 355

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

  • 模塊化公布自己的模塊功能. 其他模塊調(diào)用另外的模塊. 公布方法 如果要輸出一個鍵值對象{}梢薪,可以利用exports...
    httIsHere閱讀 522評論 0 0
  • 流是Node中最重要的組件和模式之一。在社區(qū)里有一句格言說:讓一切事務(wù)流動起來尝哆。這已經(jīng)足夠來描述在Node中流...
    宮若石閱讀 552評論 0 0
  • Node.js Stream(流) Stream 是一個抽象接口秉撇,Node 中有很多對象實現(xiàn)了這個接口。例如秋泄,對h...
    FTOLsXD閱讀 606評論 0 2
  • 1 今天我訂購并且收到我的2016年全年堅持時間管理琐馆,打卡365天的習(xí)慣養(yǎng)成的獎勵:一個可以計時的手環(huán),很開心恒序!我...
    LiHongxi閱讀 154評論 0 0
  • //聯(lián)系人:石虎QQ: 1224614774昵稱:嗡嘛呢叭咪哄 1.獲取所有本地化語言標示符[NSLocale a...
    石虎132閱讀 1,736評論 0 7