当前位置: 首页 > news >正文

electron-多线程

文章目录

    • 1. 主进程与渲染进程分离
    • 2. Node.js 多线程支持
      • Worker Threads
      • Cluster 模块
    • 3. 渲染进程中的 Web Workers
    • 4. Electron 特有的多进程通信
      • 主进程监听消息
      • 渲染进程发送消息
    • 5. 原理总结

1. 主进程与渲染进程分离

Electron 应用架构本身就基于多进程模型:

  • 主进程(Main Process):负责管理应用的生命周期、创建窗口等
  • 渲染进程(Renderer Process):负责展示网页内容,每个窗口运行在独立的渲染进程中

这种设计天然支持并发,因为每个进程可以并行运行。

2. Node.js 多线程支持

在 Electron 中,你可以利用 Node.js 提供的多线程能力:

Worker Threads

Node.js 的 worker_threads 模块允许你在主进程或渲染进程中创建真正的线程:

const { Worker, isMainThread, parentPort, workerData } = require('worker_threads');if (isMainThread) {// 主线程const worker = new Worker(__filename, {workerData: { num: 10 }});worker.on('message', (result) => {console.log('Result from worker:', result);});
} else {// 工作线程const { num } = workerData;// 执行计算密集型任务const result = fibonacci(num);parentPort.postMessage(result);
}function fibonacci(n) {if (n === 0 || n === 1) return n;let a = 0;let b = 1;for (let i = 2; i <= n; i++) {const c = a + b;a = b;b = c;}return b;
}

Cluster 模块

Node.js 的 cluster 模块可以在主进程中创建多个子进程来处理负载:

const cluster = require('cluster');
const numCPUs = require('os').cpus().length;if (cluster.isMaster) {// 主进程创建工作者进程for (let i = 0; i < numCPUs; i++) {cluster.fork();}cluster.on('exit', (worker) => {console.log(`Worker ${worker.process.pid} died`);cluster.fork(); // 重启死亡的工作者进程});
} else {// 工作者进程执行任务// 这里可以启动你的应用逻辑
}

3. 渲染进程中的 Web Workers

在渲染进程中,你可以使用标准的 Web Workers 来执行后台任务:

// 在渲染进程中
const worker = new Worker('worker.js');worker.postMessage({ command: 'calculate', data: [1, 2, 3] });worker.onmessage = function(event) {console.log('Received result from worker:', event.data);
};

对应的 worker.js 文件:

self.onmessage = function(event) {const { command, data } = event.data;if (command === 'calculate') {// 执行计算任务const result = data.reduce((sum, val) => sum + val, 0);self.postMessage({ result });}
};

4. Electron 特有的多进程通信

Electron 提供了 IPC(进程间通信)机制来协调主进程和渲染进程之间的通信:

主进程监听消息

const { ipcMain } = require('electron');ipcMain.on('asynchronous-message', (event, arg) => {console.log(arg); // 打印收到的消息event.reply('asynchronous-reply', 'pong');
});ipcMain.handle('do-heavy-work', async (event, data) => {// 执行耗时操作const result = await heavyComputation(data);return result;
});

渲染进程发送消息

const { ipcRenderer } = require('electron');ipcRenderer.send('asynchronous-message', 'ping');ipcRenderer.on('asynchronous-reply', (event, arg) => {console.log(arg); // 打印回复的消息
});// 使用 handle 方式
async function doWork() {const result = await ipcRenderer.invoke('do-heavy-work', someData);console.log(result);
}

5. 原理总结

Electron 的多线程/多进程原理可以概括为:

  1. 基于 Chromium 多进程架构:每个渲染器运行在独立的进程中,避免单个页面的崩溃影响整个应用
  2. Node.js 多线程能力:通过 worker_threads 模块实现真正的多线程执行
  3. Web Workers:在渲染进程中使用浏览器标准的 Web Workers API
  4. IPC 通信机制:通过消息传递在不同进程/线程间交换数据
  5. 资源共享与隔离:各进程拥有独立的内存空间,通过 IPC 实现数据共享
http://www.dtcms.com/a/313150.html

相关文章:

  • JDBC核心技术与预编译SQL实战
  • 计算机网络:如何将一个C类网络划分成两个子网
  • 集成电路学习:什么是USB HID人机接口设备
  • Web前端文件上传安全与敏感数据安全处理
  • 时序论文44 | TwinsFormer:通过两个交互组件重构时间序列内在依赖关系
  • [spring-cloud: 服务发现]-源码解析
  • 医院课题管理全动态流程 (AI-Enhanced, Data-Driven Research Lifecycle)
  • 位运算在权限授权中的应用及Vue3实践
  • 第2章算法分析:其他渐进复杂度符号
  • 免费非常好用的录屏软件,体积小
  • 【Java EE】Spring AOP
  • Gumbel-Softmax函数
  • AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年8月3日第155弹
  • 数据与信息的边界:非法获取计算机信息系统数据罪的司法困境与出路
  • 【十九、Javaweb-day19-Linux概述】
  • python---可变类型、不可变类型
  • Pytorch 报错-probability tensor contains either ‘inf‘, ‘nan‘ or element < 0 解决方案
  • Arrays.asList() add方法报错java.lang.UnsupportedOperationException
  • 8月3日星期日今日早报简报微语报早读
  • 多线程(四) ~ wait,join,sleep及单例与工厂模式
  • 图像识别区分指定物品与其他物体
  • 【华为机试】815. 公交路线
  • NumPy库学习(三):numpy在人工智能数据处理的具体应用及方法
  • 机器学习sklearn:支持向量机svm
  • Vue3 其它Composition API
  • Linux网络编程 --- 多路转接select
  • 推送本地项目到Gitee远程仓库
  • Selenium Web 自动化
  • 优选算法 力扣 202.快乐数 快慢双指针 解决带环问题 C++解题思路 每日一题
  • ThinkPHP5x,struts2等框架靶场复现