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

佛山家居网站全网营销深圳最好的公司排名

佛山家居网站全网营销,深圳最好的公司排名,大连seo交流群,广东东莞可能封城吗最新在前端开发中,实现多线程(或并行计算)的主要方式有以下几种,各有其适用场景和局限性: 一、Web Worker(最常用) 核心特点 独立线程:在后台线程执行,不阻塞主线程&#…

在前端开发中,实现多线程(或并行计算)的主要方式有以下几种,各有其适用场景和局限性:

一、Web Worker(最常用)

核心特点
  • 独立线程:在后台线程执行,不阻塞主线程(UI)
  • 同源限制:Worker 脚本必须与主线程同源
  • 消息传递:通过 postMessage() 与主线程通信
  • 无 DOM 访问:无法直接操作页面元素
适用场景
  • 复杂计算(如图像处理、加密)
  • 大数据处理(如 CSV 解析、JSON 格式化)
  • 长时间运行的任务(如文件上传进度计算)
// 主线程
const worker = new Worker('worker.js');worker.postMessage({ type: 'compute', data: [1, 2, 3, 4] });worker.onmessage = (event) => {console.log('计算结果:', event.data); // 输出: 10
};// worker.js (独立文件)
self.onmessage = (event) => {if (event.data.type === 'compute') {const result = event.data.data.reduce((sum, num) => sum + num, 0);self.postMessage(result);}
};

二、SharedWorker(多页面共享线程)

核心特点
  • 多页面共享:同一域名下的多个页面可访问同一个 Worker
  • 单实例:即使多个页面连接,也只创建一个 Worker 实例
  • 端口通信:通过 port 对象与各页面通信
适用场景
  • 跨标签页数据共享(如实时聊天状态同步)
  • 全局状态管理(如用户登录状态)
  • 资源共享(如数据库连接池)
// 主线程
const worker = new SharedWorker('shared-worker.js');worker.port.postMessage('Hello from page 1');worker.port.onmessage = (event) => {console.log('SharedWorker response:', event.data);
};// shared-worker.js
let connections = 0;self.onconnect = (event) => {const port = event.ports[0];connections++;port.onmessage = (event) => {port.postMessage(`Worker received: ${event.data}, connections: ${connections}`);};port.start(); // 必须显式启动端口
};

三、Service Worker(后台线程)

核心特点
  • 离线缓存:拦截网络请求,实现离线应用
  • 后台同步:在网络恢复时自动同步数据
  • 推送通知:接收服务器推送的消息
  • 独立于页面:即使页面关闭也能运行
适用场景
  • PWA(渐进式 Web 应用)
  • 离线功能(如邮件客户端)
  • 后台数据同步(如笔记自动保存)
// 注册 Service Worker
if ('serviceWorker' in navigator) {navigator.serviceWorker.register('/service-worker.js').then(() => console.log('Service Worker registered')).catch(err => console.error('Service Worker error:', err));
}// service-worker.js
self.addEventListener('fetch', (event) => {// 拦截网络请求,实现缓存策略event.respondWith(caches.match(event.request).then(cachedResponse => cachedResponse || fetch(event.request)));
});

四、WebAssembly(高性能计算)

核心特点
  • 接近原生性能:将 C/C++/Rust 代码编译为二进制格式
  • 多线程支持:通过 WebAssembly Threads(需配合 SharedArrayBuffer)
  • 与 JS 互操作:可在 Worker 中运行以避免阻塞 UI
适用场景
  • 高性能计算(如游戏引擎、科学计算)
  • 音视频编解码
  • 加密算法(如 AES、SHA-256)

rust

// Rust 代码(计算斐波那契数列)
#[wasm_bindgen]
pub fn fibonacci(n: u32) -> u32 {if n <= 1 { return n; }fibonacci(n-1) + fibonacci(n-2)
}// JavaScript 调用
import init, { fibonacci } from './fibonacci_bg.wasm';async function run() {await init();const result = fibonacci(10); // 在主线程计算(可能阻塞)console.log('Fib(10) =', result);
}// 更优实践:在 Worker 中运行 WebAssembly
const worker = new Worker('wasm-worker.js');
worker.postMessage(10);
worker.onmessage = (event) => console.log('Fib from worker:', event.data);

五、使用 Worker 池(Worker Pool)

核心特点
  • 线程复用:预创建固定数量的 Worker,避免频繁创建 / 销毁开销
  • 任务队列:自动分配任务给空闲 Worker
  • 负载均衡:优化多任务处理效率
适用场景
  • 大量相似任务(如图像批量处理)
  • 需控制并发数(如限制 CPU 使用率)
class WorkerPool {constructor(workerUrl, size = 4) {this.workers = Array(size).fill().map(() => {const worker = new Worker(workerUrl);return { worker, busy: false };});this.queue = [];}executeTask(data) {return new Promise((resolve, reject) => {const worker = this.workers.find(w => !w.busy);if (worker) {worker.busy = true;worker.worker.onmessage = (event) => {worker.busy = false;this._processQueue();resolve(event.data);};worker.worker.postMessage(data);} else {this.queue.push({ data, resolve, reject });}});}_processQueue() {if (this.queue.length === 0) return;const worker = this.workers.find(w => !w.busy);if (worker) {const { data, resolve, reject } = this.queue.shift();worker.busy = true;worker.worker.onmessage = (event) => {worker.busy = false;this._processQueue();resolve(event.data);};worker.worker.postMessage(data);}}
}// 使用示例
const pool = new WorkerPool('worker.js', 4);
pool.executeTask({ type: 'processImage', data: imageData });

六、选择建议

场景推荐技术
简单后台计算Web Worker
跨页面通信SharedWorker
离线应用 / 推送通知Service Worker
高性能计算(如游戏)WebAssembly + Web Worker
大量并发任务Worker 池

七、注意事项

  1. 数据传递限制

    • Worker 与主线程通过消息复制传递数据(非共享内存)
    • 大数据传递建议使用 Transferable Objects(如 postMessage(arrayBuffer, [arrayBuffer])
  2. 兼容性

    • Web Worker:IE10+,现代浏览器均支持
    • SharedWorker:IE 不支持,Chrome/Safari/Firefox 支持
    • Service Worker:不支持 IE,需 HTTPS(本地开发除外)
  3. 调试技巧

    • Chrome DevTools → Application → Service Workers/Workers
    • 使用 console.log 打印 Worker 内部日志
    • 捕获错误:worker.onerror = (error) => console.error(error)
http://www.yayakq.cn/news/845417/

相关文章:

  • 网站编辑建设做网站网络
  • 建一个网站需要什么资料学校官网网页制作
  • 制作网站的公司哪家比较好在线建设网站
  • wordpress建站全教程电子网站有哪些
  • 广州营销型网站建设公司哪家名气大什么能建我的网站呢
  • 网站制作公司全域营销获客公司wordpress 农业主题
  • 建立网站备案需要什么资料需求网站建设
  • 凡科互动怎么发布郑州网站关键词优化外包
  • 梅州市住房和城乡建设局官网网站广州镭拓科技网站建设公司
  • 做gif图的网站网站字体标准
  • 局域网的网站建设制作网站设计的总结
  • 网站建设c云世家网络wordpress插件云采集
  • php做网站好学吗临猗县 保障住房和建设住建网站
  • 效果图网站有哪些建设中网站如何上传图片
  • asp建设网站需要了解什么千库网官网首页登录
  • 国内html网站欣赏下载黑龙江建设网官网网站
  • 手机网站方案编写网站建设策划怎么谈
  • 廊坊网站建设方案开发国内四大高端建站公司
  • 加盟网站建设电商网站文档
  • 石家庄正定新区建设局网站注册了网站之后怎么设计
  • 网站运营 解决方案成华区网站建设
  • 鄂伦春网站建设安卓手机应用市场
  • 旅游景区网站模板wordpress 3.9.2 下载
  • 建设学院实验网站的作用wordpress显示图片
  • 做网站还需要兼容ie6吗wordpress改数据库
  • 陕西宁德建设工程有限公司网站phpcms做网站
  • 做外单的网站网页界面设计特点
  • 做婚恋网站多少钱网页制作代码模板
  • 学校培训网站开发色块网站
  • 网站维护总结烟台seo关键词排名