首頁 >web前端 >js教程 >關於Node.js時間循環的使用

關於Node.js時間循環的使用

jacklove
jacklove原創
2018-05-07 09:31:341607瀏覽

Node.js的使用效能較好,所以在使用上會經常見到,所以本文將會詳細的解說。

Node.js 是單進程單執行緒應用程序,但透過事件和回調支援並發,所以效能非常高。

Node.js 的每一個 API 都是非同步的,並作為一個獨立執行緒運行,使用非同步函數調用,並處理並發。

Node.js 基本上所有的事件機制都是用設計模式中觀察者模式實作。

Node.js 單執行緒類似進入一個while(true)的事件循環,直到沒有事件觀察者退出,每個非同步事件都會產生一個事件觀察者,如果有事件發生就呼叫該回呼函數.

事件驅動程式

Node.js 使用事件驅動模型,當web server接收到請求,就把它關閉然後進行處理,然後去服務下一個web請求。

當這個請求完成,它被放回處理佇列,當到達佇列開頭,這個結果被回傳給使用者。

這個模型非常有效率可擴展性非常強,因為webserver一直接受請求而不等待任何讀寫操作。 (這也稱為非阻塞式IO或事件驅動IO)

在事件驅動模型中,會產生一個主循環來監聽事件,當偵測到事件時觸發回調函數。


整個事件驅動的流程就是這麼實現的,非常簡潔。有點類似觀察者模式,事件相當於一個主題(Subject),而所有註冊到這個事件上的處理函數相當於觀察者(Observer)。

Node.js 有多個內建的事件,我們可以透過引入events 模組,並透過實例化EventEmitter 類別來綁定和監聽事件,如下實例:

// 引入 events 模块var events = require('events');// 创建 eventEmitter 对象var eventEmitter = new events.EventEmitter();
以下程序绑定事件处理程序:
// 绑定事件及事件的处理程序eventEmitter.on('eventName', eventHandler);
我们可以通过程序触发事件:
// 触发事件eventEmitter.emit('eventName');

實例

建立main.js 文件,程式碼如下:

// 引入 events 模块var events = require('events');// 创建 eventEmitter 对象var eventEmitter = new events.EventEmitter();// 创建事件处理程序var connectHandler = function connected() {
   console.log('连接成功。');
  
   // 触发 data_received 事件 
   eventEmitter.emit('data_received');}// 绑定 connection 事件处理程序eventEmitter.on('connection', connectHandler);
 // 使用匿名函数绑定 data_received 事件eventEmitter.on('data_received', function(){
   console.log('数据接收成功。');});// 触发 connection 事件 eventEmitter.emit('connection');console.log("程序执行完毕。");

接下來讓我們執行以上程式碼:

$ node main.js連線成功。資料接收成功。程式執行完畢。

Node 應用程式是如何運作的?

在 Node 應用程式中,執行非同步操作的函數將回呼函數作為最後一個參數, 回呼函數接收錯誤物件作為第一個參數。

接下來讓我們重新看下前面的實例,建立一個input.txt ,檔案內容如下:

菜鳥教學官網位址:www.runoob.com

建立main.js 文件,程式碼如下:

var fs = require("fs");fs.readFile('input.txt', function (err, data) {
   if (err){
      console.log(err.stack);
      return;
   }
   console.log(data.toString());});console.log("程序执行完毕");

以上詳細的介紹了Node.js的使用方法,想要了解更多的相關知識,請關注php中文網。

相關推薦:

Node.Js中實作連接埠重複使用原理詳解

Node.js註冊郵箱啟動有哪些方法

Node.Js如何實作比特幣位址

以上是關於Node.js時間循環的使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn