Node.js實戰之Buffer和Stream模塊系統深入剖析詳解
正文
JavaScript語言本身隻有字符串數據類型,沒有二進制數據類型。 但是,在處理TCP流或文件流時必須使用二進制數據。 因此,在node JS中,定義瞭一個緩沖區類來創建用於存儲二進制數據的緩沖區。
const buf = Buffer.from('runoob', 'ascii');
在node JS中,緩沖區類是與node內核一起發佈的核心庫。 緩沖庫是node JS帶來的一種存儲原始數據的方法,它允許節點JS。
console.log(buf.toString('hex')); console.log(buf.toString('base64'));
原始數據存儲在buffer類的實例中。緩沖區類似於整數數組,但它對應於V8堆內存之外的一段原始內存。
寫入緩沖區
寫入 Node 緩沖區的語法如下所示:
buf.write(string[, offset[, length]][, encoding])
- string – 寫入緩沖區的字符串。
- offset – 緩沖區開始寫入的索引值,默認為 0 。
- length – 寫入的字節數,默認為 buffer.length
- encoding – 使用的編碼。默認為 'utf8' 。
buf = Buffer.alloc(256); len = buf.write("www.runoob.com"); console.log("寫入字節數 : "+ len);
輸出為:
$node main.js 寫入字節數 : 14
buf.write(string[, offset[, length]][, encoding]) 根據參數偏移量和指定的編碼方法將參數字符串數據寫入緩沖區。偏移量的默認值為0,默認編碼方法為utf8。 長度是要寫入的字符串的字節大小。返回數字類型,指示寫入瞭多少8位字節流。 如果緩沖區沒有足夠的空間容納整個字符串,它將隻寫入部分字符串。默認情況下,長度是緩沖區長度-偏移量此方法似乎無法寫入某些字符。
buf.writeDoubleBE(value, offset[, noAssert]) 根據傳遞的偏移量和指定的endian格式將值寫入緩沖區。 註意:值必須是有效的64位雙精度值。如果參數noassert為真,則不會驗證值和偏移參數。 這意味著該值可能太大,或者偏移量可能超過緩沖區的末尾,從而導致丟棄該值。 默認值為false。
從流中讀取數據
var fs = require("fs"); var data = '';
創建可讀流
var readerStream = fs.createReadStream('input.txt');
設置編碼為 utf8。
readerStream.setEncoding('UTF8');
處理流事件 –> data, end, and error
readerStream.on('data', function(chunk) { data += chunk; });
readerStream.on('end',function(){ console.log(data); }); readerStream.on('error', function(err){ console.log(err.stack); }); console.log("程序執行完畢");
管道流
管道為輸出流到輸入流提供瞭一種機制。通常我們使用它從一個流中獲取數據並將其傳遞給另一個流。 創建一個可讀流
var readerStream = fs.createReadStream('input.txt');
創建一個可寫流
var writerStream = fs.createWriteStream('output.txt');
管道讀寫操作,讀取 input.txt 文件內容,並將內容寫入到 output.txt 文件中。
readerStream.pipe(writerStream);
鏈式流
鏈接是一種將輸出流連接到另一個流並創建多個流操作鏈的機制。鏈流通常用於管道操作。 接下來,我們使用管道和鏈來壓縮和解壓縮文件。
var fs = require("fs"); var zlib = require('zlib');
壓縮 input.txt 文件為 input.txt.gz
fs.createReadStream('input.txt') .pipe(zlib.createGzip()) .pipe(fs.createWriteStream('input.txt.gz'));
執行上述操作後,我們可以看到輸入Txt壓縮文件input.Txt.gz。 接下來,讓我們解壓文件並創建解壓JS文件,代碼如下:
var fs = require("fs"); var zlib = require('zlib');
解壓 input.txt.gz 文件為 input.txt
fs.createReadStream('input.txt.gz') .pipe(zlib.createGunzip()) .pipe(fs.createWriteStream('input.txt'));
模塊系統
以便啟用節點的文件。js相互調用,節點。js提供瞭一個簡單的模塊系統。 模塊是JS應用程序的基本組件,文件和模塊是一一對應的。 換句話說,node JS文件是一個模塊。該文件可以是JavaScript代碼、JSON或編譯的C/C++擴展。 hello.js
function Hello() { var name; this.setName = function(thyName) { name = thyName; }; this.sayHello = function() { console.log('Hello ' + name); }; };
模塊接口中唯一的變化是使用模塊Exports=Hello,而不是Exports world=function(){} 當模塊被外部引用時,其接口對象是要輸出的Hello對象本身,而不是原始導出。
var Hello = require('./hello'); hello = new Hello(); hello.setName('BYVoid'); hello.sayHello();
以上就是Node.js實戰之Buffer和Stream模塊系統深入剖析詳解的詳細內容,更多關於Node.js模塊系統Buffer Stream的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- Node.js中fs模塊的使用方法
- 如何用Node.js編寫內存效率高的應用程序
- Node.js中SerialPort(串口)模塊使用
- Node.js原理阻塞和EventEmitter及其繼承的運用實戰
- 如何在Nodejs中使用模塊fs文件系統