国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

深入了解Node.js中的一些特性

2019-11-20 14:06:23
字體:
來源:轉載
供稿:網(wǎng)友

Node.js作為一門新興的后臺語言,旨在幫助程序員快速構建可伸縮的應用程序。Node.js有很多吸引人的地方,有關它的報道不計其數(shù),本文將針對EventEmitter、Streams、Coding Style、Linting、Coding Style等特性進行分析探討,幫助用戶對Node.js有更深入的了解。

作為一個基于Chrome JavaScript 運行時建立的平臺,我們對JavaScript 的相關認識,似乎都可應用于node應用程序之上;無需額外的語言擴展或修飾,我們便可以把前端編程的經驗應用于后端編程。

EventEmitter(事件發(fā)送器)

首先應該先了解EventEmitter模型。它可以發(fā)送一個事件以及讓消費者訂閱感興趣的事件。我們可以把它看成是向一個異步函數(shù)進行回調傳遞模式的擴展。特別是,當需要進行多次回調時,EventEmitter會更顯優(yōu)勢。

例如,有一個調用者向遠程服務器發(fā)送了一個“列出文件”的請求。你可能想對返回結果進行分組,對每一個分組進行一次回調處理。EventEmitter模型可以讓你在每一個分組上發(fā)送“文件”回調,當全部操作完成時進行“結束”處理。

使用EventEmitter時,只需設置好相關事件和參數(shù)。

復制代碼 代碼如下:

var EventEmitter = require('events').EventEmitter; 
var util = require('util'); 
 
function MyClass() { 
  if (!(this instanceof MyClass)) return new MyClass(); 
 
  EventEmitter.call(this); 
 
  var self = this; 
  setTimeout(function timeoutCb() { 
    self.emit('myEvent', 'hello world', 42); 
  }, 1000); 

util.inherits(MyClass, EventEmitter); 

MyClass構造函數(shù)創(chuàng)建了一個時間觸發(fā)器,觸發(fā)延時為1s,觸發(fā)事件為myEvent。要使用相關事件,需要執(zhí)行on()方法:

復制代碼 代碼如下:

var myObj = new MyClass(); 
var start = Date.now(); 
myObj.on('myEvent', function myEventCb(str, num) { 
  console.log('myEvent triggered', str, num, Date.now() - start); 
}); 

這里要注意的是,訂閱的EventEmitter事件雖然是異步事件,但當時間觸發(fā)時,監(jiān)聽方的動作是會同步的。因此如果上述myEvent事件有10個監(jiān)聽者,所有的監(jiān)聽會被按次序調用而不用等候事件的循環(huán)。

如果EventEmitter的一個子類生成了一個emit(‘error')事件,但是無任何的監(jiān)聽方對此進行訂閱,那么EventEmitter基類會拋出一個異常,從而導致當執(zhí)行process對象時觸發(fā)uncaughtException事件。

verror

verror是基類Error的擴展,可以讓我們使用printf字符格式定義輸出消息。

Streams(流)

如果有一個非常龐大的文件需要處理,理想的方法應該是讀一部分,寫一部分,不管文件有多大,只要時間允許,總會處理完成,這里就需要用到流的概念。Streams是Node中另一個廣泛使用的模型,在Node中是EventEmitter的實現(xiàn)。提供了可讀、可寫或者是全雙工接口。它是一個抽象接口,提供的常規(guī)操作事件包括:readable、writable、 drain、data、 end及close。如果我們能夠使用pipeline(管道)來對這些事件進行有效整合,將可實現(xiàn)功能更強大的交互操作。

透過使用.pipe(),可以讓Note通過pipeline與back-pressure進行通信。back-pressure的意思是:只讀取那些能夠寫入的,或只寫入那些能夠讀取的。

例如我們現(xiàn)在把來自stdin的數(shù)據(jù)發(fā)送到一個本地文件和遠程服務器:

復制代碼 代碼如下:

var fs = require('fs');
var net = require('net');

var localFile = fs.createWriteStream('localFile.tmp');

net.connect('255.255.255.255', 12345, function(client) {
  process.stdin.pipe(client);
  process.stdin.pipe(localFile);
});

而如果我們想發(fā)送數(shù)據(jù)到一個本地文件,并想使用gunzip對這個stream進行壓縮,可以這樣做:

復制代碼 代碼如下:

var fs = require('fs');
var zlib = require('zlib');

process.stdin.pipe(zlib.createGunzip()).pipe(fs.createWriteStream('localFile.tar'));

如果想對stream有更多了解,請點擊這里

Control Flow(流程控制)

由于JS中有第一類對象,閉包等功能概念,因而能夠容易地對回調權限進行定義。這在進行原型設計時是非常方便的,能夠對邏輯權限按需進行整合。但是同時容易造成使用笨拙的內置函數(shù)。

例如我們想按次序讀入一系列文件,然后執(zhí)行某個任務:

復制代碼 代碼如下:

fs.readFile('firstFile', 'utf8', function firstCb(err, firstFile) {
  doSomething(firstFile);
  fs.readFile('secondFile', 'utf8', function secondCb(err, secondFile) {
    doSomething(secondFile);
    fs.readFile('thirdFile', 'utf8', function thirdCb(err, thirdFile) {
      doSomething(thirdFile);
    });
  });
});

這個模式存在的問題是:

1.這些代碼的邏輯非常散亂無序,相關的操作流程難以理解。
2.沒有任何差錯或異常處理。
3.JS中閉包內存泄漏是非常常見的,并難以診斷和探測。

如果我們想在一個輸入集上進行一系列異步操作,使用一個流程控制庫是更明智的選擇。這里使用的是vasync。

vasync是一個流程控制庫,其思路來源于異步操作。它的特別之處是能夠讓消費者對某個任務處理過程進行查看和觀察。這些信息對研究某個錯誤的產生過程是非常有用的。

Coding Style(編程風格)

編程風格可謂最具爭議性的話題,因為很多時候都是隨性的。蘿卜白菜,各有所愛。重要的是找到適合個人和團隊的風格。一些傳統(tǒng)的傳承或許能夠讓Node開發(fā)之旅變得更美好。

1.為函數(shù)命名
2.盡量對所有函數(shù)進行命名。
3.避免閉包
4.不要在某個函數(shù)中定義其它函數(shù)。這可減少很多想不到的閉包內存泄露意外。
5.更多和更小巧的函數(shù)

V8 JIT雖然是一個功能強大的引擎,但是更小巧和精簡的函數(shù)會與V8結合得更好。進一步說,如果我們的函數(shù)都是小巧玲瓏的(100行左右),我們自己進行閱讀和維護時也會感謝自己的。

用編程方式檢查風格:保持風格一致性,并使用一個檢查工具來加強。我們使用的是jsstyle。

Linting(代碼檢查)

Lint工具可以在不運行情況下進行代碼的靜態(tài)分析,檢查出潛在的錯誤和風險,例如在caseswitch中遺漏了break語句。Lint不簡單地等同于風格檢查,它更針對于客觀的風險分析,而不是主觀的風格選擇。我們使用的javascriptlint,它里面有豐富檢查項目。

Logging(日志記錄)

當我們進行程序設計和編碼時,需要有長遠的目光。特別是要考慮好使用什么工具來進行調試。極好的第一步是進行有效日志記錄。我們需要對信息進行識別,看看什么是調試時特別留意的,什么是運行時用來分析研究的。這里推薦使用Bunyan,一個直接的Node.js日志記錄庫,數(shù)據(jù)輸出格式是JSON ,要了解更多信息,請點擊這里。

Client Server

如果一款應用具備分布式處理能力,在市場上會更有吸引力。類似的接口可以用HTTP RESTFul API或原始的TCP JSON來描述。這可以讓開發(fā)者把Node上的經驗與異步網(wǎng)絡環(huán)境相結合,以及把streams的使用與分布式可擴展式系統(tǒng)相結合。

常用工具:

1. restify

簡單來說,這是一個用于構建REST服務的工具。它提供了良好的查看和調試處理支援,同時支持Bunyan與DTrace。

2. fast

fast是一款以TCP來處理JSON消息的輕量級工具。提供了DTrace支持,能夠讓我們迅速地對服務器客戶端進行性能特征識別。

3. workflow

workflow構建于restify之上,能夠對一系列遠程服務和API進行業(yè)務流程定義。例如:錯誤狀態(tài),超時,重新連接,擁塞處理等。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 辽宁省| 炎陵县| 汉川市| 恩施市| 句容市| 禄丰县| 鄂托克前旗| 聂拉木县| 绍兴市| 西华县| 南漳县| 丰都县| 蕉岭县| 桐乡市| 大厂| 夏邑县| 郯城县| 拉萨市| 建湖县| 尼勒克县| 江油市| 永济市| 荥阳市| 镇坪县| 稷山县| 房产| 苍南县| 镇远县| 广河县| 容城县| 达拉特旗| 安陆市| 青铜峡市| 孟村| 禹州市| 手机| 徐水县| 万安县| 云阳县| 深圳市| 阳谷县|