简介之前的文章中提到了,nodejs中有两种线程,一种是event loop用来相应用户的请求和处理各种callback。另一种就是worker pool用来处理各种耗时操作。可惜的是webworker-threads的最后一次更新还是在2年前,而在最新的nodejs 12中,根本无法使用。而webworker-threads的作者则推荐了一个新的lib叫做web-worker。web-worker是构建于nodejs的worker_threads之上的,本文将会详细讲解worker_threads和web-worker的使用。worker_threadsworker_threads模块的源代码源自lib/worker_threads.js,它指的是工作线程,可以开启一个新的线程来并行执行javascript程序。worker_threads主要用来处理CPU密集型操作,而不是IO操作,因为nodejs本身的异步IO已经非常强大了。worker_threads中主要有5个属性,3个class和3个主要的方法。MessageChannelMessageChannel代表的是一个异步双向通信channel。MessageChannel中没有方法,主要通过MessageChannel来连接两端的MessagePort。当我们使用new MessageChannel()的时候,会自动创建两个MessagePort。

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法

nodejs中使用worker_threads来创建新的线程的方法