本文使用的是node-v14.14.0版本
个人理解多线程就是单独开辟出另外的空间同时执行代码
官网给出的实例这里就不作展示了,正常要是使用的话也不可能把代码都放到一个文件中执行下面先上段代码注意里面的文件名称嗷!
app.js
const path = require("path");
const { Worker } = require('worker_threads');
//这里传了两个参数一个是你要开进程的文件一个是在加载时候传入线程的数据
//注意这里是不可以传一个函数过去的你只能传基本类型和引用类型过去
var work1 = new Worker(path.join(__dirname, './work1.js'), {
workerData: {
data: [
{
a: 1111
}
]
}
});
setInterval(() => {//定时向子进程发送数据
work1.postMessage({ data: ["主线程", 3, 4] });
}, 2000)
work1.on("message", (msg) => {//接收子进程传过来的数据
console.log("子线程传来的数据", msg)
})
work1.js
const { parentPort, workerData } = require('worker_threads');
//接收主线程传来的参数
console.log(workerData.data);
setInterval(() => {
//给主线程发送消息
parentPort.postMessage({ data: ["子线程", 3, 4] });
}, 3000)
//接收主线程发过来的消息
parentPort.on("message",(msg)=>{
console.log("主线程发过来的信息",msg)
})
如图
这就完成了最简单的数据互传,可以根据自己的需求进行修改