gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

聊聊Node.js + worker_threads如何實現(xiàn)多線程?(詳解)

本篇文章帶大家了解一下worker_threads 模塊,介紹一下在Node中如何使用worker_threads實現(xiàn)多線程,以及利用worker_threads執(zhí)行斐波那契數(shù)列作為實踐例子,希望對大家有所幫助!

聊聊Node.js + worker_threads如何實現(xiàn)多線程?(詳解)

通常情況下,Node.js被認(rèn)為是單線程。由主線程去按照編碼順序一步步執(zhí)行程序代碼,一旦遇到同步代碼阻塞,主線程就會被占用,后續(xù)的程序代碼的執(zhí)行都會被卡住。沒錯Node.js的單線程指的是主線程是"單線程"。

為了解決單線程帶來的問題,本文的主角worker_threads出現(xiàn)了。worker_threads首次在Node.js v10.5.0作為實驗性功能出現(xiàn),需要命令行帶上--experimental-worker才能使用。直到v12.11.0穩(wěn)定版才能正式使用。

本文將會介紹worker_threads的使用方式,以及利用worker_threads執(zhí)行斐波那契數(shù)列作為實踐例子。

先決條件

閱讀并食用本文,需要先具備:

  • 安裝了 Node.js v12.11.0 及以上版本
  • 掌握 JavaScript 同步和異步編程的基礎(chǔ)知識
  • 掌握 Node.js 的工作原理

worker_threads 介紹

worker_threads 模塊允許使用并行執(zhí)行 JavaScript 的線程。

工作線程對于執(zhí)行 CPU 密集型的 JavaScript 操作很有用。 它們對 I/O 密集型的工作幫助不大。 Node.js 內(nèi)置的異步 I/O 操作比工作線程更高效。

child_processcluster 不同,worker_threads 可以共享內(nèi)存。 它們通過傳輸 ArrayBuffer 實例或共享 SharedArrayBuffer 實例來實現(xiàn)。

由于以下特性,worker_threads已被證明是充分利用CPU性能的最佳解決方案:

  • 它們運行具有多個線程的單個進(jìn)程。

  • 每個線程執(zhí)行一個事件循環(huán)。

  • 每個線程運行單個 JS 引擎實例。

  • 每個線程執(zhí)行單個 Nodejs 實例。

worker_threads 如何工作

worker_threads通過執(zhí)行主線程指定的腳本文件來工作。每個線程都在與其他線程隔離的情況下執(zhí)行。但是,這些線程可以通過消息通道來回傳遞消息。

主線程使用worker.postMessage()函數(shù)使用消息通道,而工作線程使用parentPort.postMessage()函數(shù)。

通過官方示例代碼加強了解:

const {   Worker, isMainThread, parentPort, workerData } = require('worker_threads');  if (isMainThread) {   module.exports = function parseJSAsync(script) {     return new Promise((resolve, reject) => {       const worker = new Worker(__filename, {         workerData: script       });       worker.on('message', resolve);       worker.on('error', reject);       worker.on('exit', (code) => {         if (code !== 0)           reject(new Error(`Worker stopped with exit code ${code}`));       });     });   }; } else {   const { parse } = require('some-js-parsing-library');   const script = workerData;   parentPort.postMessage(parse(script)); }

上述代碼主線程工作線程都使用同一份文件作為執(zhí)行腳本(__filename為當(dāng)前執(zhí)行文件路徑),通過isMainThread來區(qū)分主線程工作線程運行時邏輯。當(dāng)模塊對外暴露方法parseJSAsync被調(diào)用時候,都將會衍生子工作線程去執(zhí)行調(diào)用parse函數(shù)。

worker_threads 具體使用

在本節(jié)使用具體例子介紹worker_threads的使用

創(chuàng)建工作線程腳本文件workerExample.js:

const { workerData, parentPort } = require('worker_threads') parentPort.postMessage({ welcome: workerData })

創(chuàng)建主線程腳本文件main.js:

const { Worker } = require('worker_threads')  const runWorker = (workerData) => {     return new Promise((resolve, reject) => {         // 引入 workerExample.js `工作線程`腳本文件         const worker = new Worker('./workerExample.js', { workerData });         worker.on('message', resolve);         worker.on('error', reject);         worker.on('exit', (code) => {             if (code !== 0)                 reject(new Error(`stopped with  ${code} exit code`));         })     }) }  const main = async () => {     const result = await runWorker('hello worker threads')     console.log(result); }  main().catch(err => console.error(err))

控制臺命令行執(zhí)行:

node main.js

輸出:

{ welcome: 'hello worker threads' }

worker_threads 運算斐波那契數(shù)列

在本節(jié)中,讓我們看一下 CPU 密集型示例,生成斐波那契數(shù)列。

如果在沒有工作線程的情況下完成此任務(wù),則會隨著nth期限的增加而阻塞主線程。

創(chuàng)建工作線程腳本文件worker.js

const {parentPort, workerData} = require("worker_threads");  parentPort.postMessage(getFibonacciNumber(workerData.num))  function getFibonacciNumber(num) {     if (num === 0) {         return 0;     }     else if (num === 1) {         return 1;     }     else {         return getFibonacciNumber(num - 1) + getFibonacciNumber(num - 2);     } }

創(chuàng)建主線程腳本文件main.js:

const {Worker} = require("worker_threads");  let number = 30;  const worker = new Worker("./worker.js", {workerData: {num: number}});  worker.once("message", result => {     console.log(`${number}th Fibonacci Result: ${result}`); });  worker.on("error", error => {     console.log(error); });  worker.on("exit", exitCode => {     console.log(`It exited with code ${exitCode}`); })  console.log("Execution in main thread");

控制臺命令行執(zhí)行:

node main.js

輸出:

Execution in main thread 30th Fibonacci Result: 832040 It exited with code 0

main.js文件中,我們從類的實例創(chuàng)建一個工作線程,Worker正如我們在前面的示例中看到的那樣。

為了得到結(jié)果,我們監(jiān)聽 3 個事件,

  • message響應(yīng)工作線程發(fā)出消息。
  • exit工作線程停止執(zhí)行的情況下觸發(fā)的事件。
  • error發(fā)生錯誤時觸發(fā)。

我們在最后一行main.js,

console.log("Execution in main thread");

通過控制臺的輸出可得,主線程并沒有被斐波那契數(shù)列運算執(zhí)行而阻塞。

因此,只要在工作線程中處理 CPU 密集型任務(wù),我們就可以繼續(xù)處理其他任務(wù)而不必?fù)?dān)心阻塞主線程。

結(jié)論

Node.js 在處理 CPU 密集型任務(wù)時一直因其性能而受到批評。通過有效地解決這些缺點,工作線程的引入提高了 Node.js 的功能。

有關(guān)worker_threads

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
国产v亚洲v天堂无码久久久| 97xxxxx| 久久久亚洲精品无码| 国产精品波多野结衣| 国产精品探花在线播放| 亚洲36d大奶网| 国产精品亚洲天堂| av日韩在线看| 美女av免费在线观看| 久久这里只精品| 亚洲乱码日产精品bd在线观看| 免费不卡av在线| 亚洲xxxx2d动漫1| 妞干网这里只有精品| 无罩大乳的熟妇正在播放| 中文久久久久久| 国产av熟女一区二区三区 | 欧美视频在线播放一区| 91插插插插插插插插| 日韩第一页在线观看| 成人在线免费观看av| 中文字幕制服丝袜在线| aa在线观看视频| 午夜av中文字幕| 国产女女做受ⅹxx高潮| 国产树林野战在线播放| 黄色国产小视频| 国产中文字幕乱人伦在线观看| 亚洲黄色av网址| 缅甸午夜性猛交xxxx| 五月天av影院| 日韩av手机版| 99在线免费视频观看| 黄色小视频免费网站| 日韩免费一级视频| av一区二区三区免费观看| 五月激情婷婷在线| 日韩欧美xxxx| 国内精品在线观看视频| 日本高清免费观看| 国产理论在线播放| 拔插拔插海外华人免费| 国产精品免费看久久久无码| 邪恶网站在线观看| 精品一卡二卡三卡| 天堂…中文在线最新版在线| 一级日本黄色片| 鲁一鲁一鲁一鲁一av| 久久久久国产精品熟女影院| 女人色极品影院| 久久久国产精华液999999 | 国产一区二区三区播放| 小泽玛利亚视频在线观看| 在线视频一二区| 亚洲怡红院在线| 欧美美女一级片| 欧美黄色性生活| 午夜两性免费视频| 无限资源日本好片| 男女污污的视频| 丰满少妇在线观看| 中文字幕国产传媒| 777视频在线| 亚洲三级在线观看视频| 在线黄色免费看| 自拍偷拍21p| 9久久婷婷国产综合精品性色| 国产成人精品无码播放| jizz欧美激情18| 午夜天堂在线视频| 国产系列第一页| 国产免费内射又粗又爽密桃视频| 日韩精品一区二区三区四| 久草视频国产在线| 国产精品亚洲αv天堂无码| 日韩有码免费视频| 欧美日韩一区二区三区69堂| 国产成人美女视频| 久久免费一级片| 久久久一本二本三本| 国产精品人人妻人人爽人人牛| 成人中文字幕av| 免费看av软件| 日本免费不卡一区二区| www.日本一区| 日韩精品一区二区在线视频| 免费观看亚洲视频| 成熟了的熟妇毛茸茸| 国产aaaaa毛片| 国产欧美久久久久| 无码人妻精品一区二区三区66| 日本美女视频一区| av免费看网址| 亚洲欧美手机在线| 噜噜噜久久亚洲精品国产品麻豆| 午夜免费福利在线| 欧美乱做爰xxxⅹ久久久| 妓院一钑片免看黄大片| 欧美精品久久96人妻无码| 国产91在线免费| 中文字幕制服丝袜在线| 日韩精品视频久久| 自拍一级黄色片| 久久无码高潮喷水| 精品人妻大屁股白浆无码| 日韩一级片播放| 蜜臀av无码一区二区三区| www.色欧美| 国产视频在线视频| 免费不卡av在线| 九九九久久久久久久| 欧美 日韩 国产一区| 在线观看av的网址| 红桃视频 国产| ww国产内射精品后入国产| 老汉色影院首页| 亚洲va在线va天堂va偷拍| aa免费在线观看| 日韩激情视频一区二区| 国产成年人视频网站| 亚洲 中文字幕 日韩 无码| 3d动漫一区二区三区| 国产又粗又长又爽视频| 欧美日韩视频免费在线观看| 日韩肉感妇bbwbbwbbw| 日韩视频第二页| 欧美一区二区视频在线播放| 6080国产精品| 亚洲va综合va国产va中文| 97av视频在线观看| 黄www在线观看| 男女超爽视频免费播放| 久操手机在线视频| 国内自拍中文字幕| 日本xxxxx18| 国产日本欧美在线| 亚洲av毛片在线观看| 91亚洲精品久久久蜜桃借种| 国产精品区在线| 手机免费看av网站| 一二三av在线| 超碰成人在线免费观看| 91大神免费观看| 国产精品一二三在线观看| 91精品一区二区三区四区| 老司机午夜免费福利视频| 蜜臀av性久久久久蜜臀av| 国产精品第157页| 国产97在线 | 亚洲| 国产免费视频传媒| 免费看涩涩视频| 6080国产精品| www.日本在线视频| 日韩人妻精品无码一区二区三区| 中文字幕 日韩 欧美| 午夜激情影院在线观看| 天天成人综合网| 五十路熟女丰满大屁股| 黑森林福利视频导航| 在线观看国产一级片| 午夜影院免费版| 男人添女人下面高潮视频| 91av在线免费播放| 日日干日日操日日射| www.欧美黄色| 热久久精品免费视频| 久久国产精品免费观看| 免费国产a级片| 性欧美1819| 国产二区视频在线| 蜜臀av午夜一区二区三区| 亚洲另类第一页| www.日本在线视频| 欧美日韩大尺度| 狠狠精品干练久久久无码中文字幕| 自慰无码一区二区三区| 日本中文字幕观看| a级黄色一级片| 日韩高清第一页| 乱人伦xxxx国语对白| 中文字幕 日韩 欧美| 国产精品12345| 亚洲欧美日韩一二三区| 欧美日韩在线中文| 成人毛片100部免费看| 成年人视频在线免费| 特色特色大片在线| 中文字幕第38页| 波多野结衣家庭教师在线播放| 成人性生交视频免费观看| 十八禁视频网站在线观看| 妞干网视频在线观看| eeuss中文| 色片在线免费观看| 日av中文字幕| 成 年 人 黄 色 大 片大 全| 国产成年人在线观看| 久热在线视频观看| 一级黄色香蕉视频| 国产精品97在线|