• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 聊聊Node.js + worker_threads如何实现多线程?(详解)

聊聊Node.js + worker_threads如何实现多线程?(详解)

作者:站长图库 字体:[增加 减小] 来源:互联网

站长图库向大家介绍了Node.js + worker_threads,Node.js多线程等相关知识,希望对您有所帮助

本篇文章带大家了解一下worker_threads 模块,介绍一下在Node中如何使用worker_threads实现多线程,以及利用worker_threads执行斐波那契数列作为实践例子,希望对大家有所帮助!


聊聊Node.js + worker_threads如何实现多线程?(详解)


通常情况下,Node.js被认为是单线程。由主线程去按照编码顺序一步步执行程序代码,一旦遇到同步代码阻塞,主线程就会被占用,后续的程序代码的执行都会被卡住。没错Node.js的单线程指的是主线程是"单线程"。

为了解决单线程带来的问题,本文的主角worker_threads出现了。worker_threads首次在Node.js v10.5.0作为实验性功能出现,需要命令行带上--experimental-worker才能使用。直到v12.11.0稳定版才能正式使用。

本文将会介绍worker_threads的使用方式,以及利用worker_threads执行斐波那契数列作为实践例子。

先决条件

阅读并食用本文,需要先具备:

安装了 Node.js v12.11.0 及以上版本

掌握 JavaScript 同步和异步编程的基础知识

掌握 Node.js 的工作原理

worker_threads 介绍

worker_threads 模块允许使用并行执行 JavaScript 的线程。

工作线程对于执行 CPU 密集型的 JavaScript 操作很有用。 它们对 I/O 密集型的工作帮助不大。 Node.js 内置的异步 I/O 操作比工作线程更高效。

与 child_process 或 cluster 不同,worker_threads 可以共享内存。 它们通过传输 ArrayBuffer 实例或共享 SharedArrayBuffer 实例来实现。

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

它们运行具有多个线程的单个进程。

每个线程执行一个事件循环。

每个线程运行单个 JS 引擎实例。

每个线程执行单个 Nodejs 实例。

worker_threads 如何工作

worker_threads通过执行主线程指定的脚本文件来工作。每个线程都在与其他线程隔离的情况下执行。但是,这些线程可以通过消息通道来回传递消息。

主线程使用worker.postMessage()函数使用消息通道,而工作线程使用parentPort.postMessage()函数。

通过官方示例代码加强了解:

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));}

上述代码主线程与工作线程都使用同一份文件作为执行脚本(__filename为当前执行文件路径),通过isMainThread来区分主线程与工作线程运行时逻辑。当模块对外暴露方法parseJSAsync被调用时候,都将会衍生子工作线程去执行调用parse函数。

worker_threads 具体使用

在本节使用具体例子介绍worker_threads的使用

创建工作线程脚本文件workerExample.js:

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

创建主线程脚本文件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))

控制台命令行执行:

node main.js

输出:

{ welcome: 'hello worker threads' }


worker_threads 运算斐波那契数列

在本节中,让我们看一下 CPU 密集型示例,生成斐波那契数列。

如果在没有工作线程的情况下完成此任务,则会随着nth期限的增加而阻塞主线程。

创建工作线程脚本文件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);    }}

创建主线程脚本文件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 => {    
  


 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 聊聊Node.js + worker_threads如何实现多线程?(详解)

相关文章

  • 织梦DedeCMS V5.7前台搜索打开慢的原因及解决方法
  • 11个SEO细节提升网站权威性
  • 浅谈CSS如何实现九宫格提示超出数量
  • 详解PHP中__construct()构造方法
  • Discuz怎么添加广告位?自定义广告位方法浅析
  • DedeCMS关键词替换问题较完美解决方案
  • 教你用PHP实现微信小程序人脸识别刷脸登录功能
  • css中实现背景透明的三种方式
  • PHP调用今天的日期几月星期几
  • jQuery怎么删除元素但保留子元素

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • Ajax实现登录案例
    • DEDE建站内部SEO优化
    • 关键词组合的SEO优化策略
    • 使用织梦DdedCMS添加文章时同时更新所有单页面的
    • CDR绘制红色枫叶背景插画
    • Photoshop制作超酷的哥特字体教程
    • JS去除腾讯爱奇艺优酷视频右上角LOGO
    • MacOS下PHP7.1升级到PHP7.4.15的方法
    • CorelDraw制作金色质感小球教程
    • uniapp实现微信小程序全局分享的示例代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有