欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

輕松創(chuàng)建nodejs服務(wù)器(7):阻塞操作的實(shí)現(xiàn)

 更新時(shí)間:2014年12月18日 11:14:20   投稿:junjie  
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(7):阻塞操作的實(shí)現(xiàn),本文先是組出了代碼,然后對(duì)代碼一一分析,需要的朋友可以參考下

我們來(lái)看一下什么是阻塞操作;

我模擬一個(gè)sleep()方法來(lái)使hello star延遲10秒打印。

requestHandlers.js

復(fù)制代碼 代碼如下:

function start() {
  console.log("Request handler 'start' was called.");
  function sleep(milliSeconds) {
 var startTime = new Date().getTime();
 while (new Date().getTime() < startTime + milliSeconds);
  }
  sleep(10000);
  return "Hello Start";
}
 
function upload() {
  console.log("Request handler 'upload' was called.");
  return "Hello Upload";
}
 
exports.start = start;
exports.upload = upload;

請(qǐng)求/start的時(shí)候,延遲了10秒才打印。

請(qǐng)求/upload的時(shí)候,并不會(huì)受影響。

接下來(lái)做一個(gè)試驗(yàn):

在第一個(gè)瀏覽器窗口的地址欄中輸入 http://localhost:8888/start,但是先不要打開(kāi)它!

在第二個(gè)瀏覽器窗口的地址欄中輸入 http://localhost:8888/upload,同樣的,先不要打開(kāi)它!

我們?cè)诘谝粋€(gè)窗口中(“/start”)按下回車,然后快速切換到第二個(gè)窗口中(“/upload”)按下回車。

注意,發(fā)生了什么:

/start URL 加載花了 10 秒,這和我們預(yù)期的一樣。

/upload URL 居然也花了 10 秒!

可以它在對(duì)應(yīng)的請(qǐng)求處理程序中并沒(méi)有類似于 sleep()這樣的操作啊,這是什么問(wèn)題?

原因就是start()包含了阻塞操作。形象的說(shuō)就是“它阻塞了所有其他的處理工作”。

Node.js 是單線程的,它可以在不新增額外線程的情況下對(duì)任務(wù)進(jìn)行并行處理。

它通過(guò)事件輪詢(event loop)來(lái)實(shí)現(xiàn)并行操作,我們應(yīng)該要充分利用這一點(diǎn) —— 盡可能的避免阻塞操作,取而代之,多使用非阻塞操作。

下一節(jié)我們將介紹一下如何實(shí)現(xiàn)非阻塞操作。

相關(guān)文章

最新評(píng)論