分享更有价值
被信任是一种快乐

Node.js + worker_threads怎么实现多线程

文章页正文上

这篇文章主要介绍“Node.js + 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 模块允许使用并行执行 JavaScript 的线程。工作线程对于执行 CPU 密集型的 JavaScript 操作很有用。 它们对 I/O 密集型的工作帮助不大。 Node.js 内置的异步 I/O 操作比工作线程更高效。与 child_processcluster 不同,worker_threads 可以共享内存。 它们通过传输 ArrayBuffer 实例或共享 SharedArrayBuffer 实例来实现。由于以下特性,worker_threads已被证明是充分利用CPU性能的最佳解决方案:它们运行具有多个线程的单个进程。每个线程执行一个事件循环。每个线程运行单个 JS 引擎实例。每个线程执行单个 Nodejs 实例。worker_thread免费云主机、域名s通过执行主线程指定的脚本文件来工作。每个线程都在与其他线程隔离的情况下执行。但是,这些线程可以通过消息通道来回传递消息。主线程使用worker.postMessage()函数使用消息通道,而工作线程使用parentPort.postMessage()函数。通过官方示例代码加强了解:上述代码主线程工作线程都使用同一份文件作为执行脚本(__filename为当前执行文件路径),通过isMainThread来区分主线程工作线程运行时逻辑。当模块对外暴露方法parseJSAsync被调用时候,都将会衍生子工作线程去执行调用parse函数。在本节使用具体例子介绍worker_threads的使用创建工作线程脚本文件workerExample.js:创建主线程脚本文件main.js:控制台命令行执行:输出:在本节中,让我们看一下 CPU 密集型示例,生成斐波那契数列。如果在没有工作线程的情况下完成此任务,则会随着nth期限的增加而阻塞主线程。创建工作线程脚本文件worker.js创建主线程脚本文件main.js:控制台命令行执行:输出:在main.js文件中,我们从类的实例创建一个工作线程,Worker正如我们在前面的示例中看到的那样。为了得到结果,我们监听 3 个事件,message响应工作线程发出消息。exit工作线程停止执行的情况下触发的事件。error发生错误时触发。我们在最后一行main.js,通过控制台的输出可得,主线程并没有被斐波那契数列运算执行而阻塞。因此,只要在工作线程中处理 CPU 密集型任务,我们就可以继续处理其他任务而不必担心阻塞主线程。关于“Node.js + worker_threads怎么实现多线程”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注云技术行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: 如何实现CSS3径向渐变中大鱼吃小鱼之孤单的大鱼效果图

本篇文章给大家分享的是有关如何实现CSS3径向渐变中大鱼吃小鱼之孤单的大鱼效果图,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。喜欢钓鱼还没那个技术钓到鱼,下面画条大鱼安慰我一下柔弱的心灵。先给大家…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册