感受webWorker

news2024/10/7 5:26:35

B站视频     git完整代码   

之前遇到的场景

1、vxe表格计算1000多条数极值/算数平方根的时候。

2、大文件上传时计算hashCode时候

一、不使用webWorker

目录结构

代码

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
        console.log('开始执行了')
        console.time('总的执行时间')

      function fb(n) {
        if (n == 1 || n == 2) {
          return 1;
        }
        return fb(n - 1) + fb(n - 2);
      }
      console.time("fb执行时间2");
      var result = fb(43);
      console.timeEnd("fb执行时间2");

      function fb2(n) {
        if (n == 1 || n == 2) {
          return 1;
        }
        return fb2(n - 1) + fb2(n - 2);
      }
      console.time("fb执行时间2");
      var result = fb2(43);
      console.timeEnd("fb执行时间2");

      function fb2(n) {
        if (n == 1 || n == 2) {
          return 1;
        }
        return fb2(n - 1) + fb2(n - 2);
      }
      console.time("fb执行时间2");
      var result = fb2(43);
      console.timeEnd("fb执行时间2");

      console.timeEnd('总的执行时间')
      console.log('执行结束了')
    </script>
  </body>
</html>

运行结果

二、使用webWorker

目录结构

test.html

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width= , initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
      var worker1 = new Worker("worker.js");
      var worker2 = new Worker("worker2.js");
      var worker3 = new Worker("worker3.js");
      worker1.onmessage = (e) => {
        console.log(e.data);
      };
      worker2.onmessage = (e) => {
        console.log(e.data);
      };
      worker3.onmessage = (e) => {
        console.log(e.data);
      };
    </script>
  </body>
</html>

worker.js

//   斐波那契数列,模拟一个很耗时的计算过程
function fb(n) {
  if (n == 1 || n == 2) {
    return 1;
  }
  return fb(n - 1) + fb(n - 2);
}
console.time("fb执行时间1");
var result = fb(43);
console.timeEnd("fb执行时间1");
self.postMessage("worker");
// 在worker里self相当于global/window全局变量

worker2.js

//   斐波那契数列,模拟一个很耗时的计算过程
function fb(n) {
  if (n == 1 || n == 2) {
    return 1;
  }
  return fb(n - 1) + fb(n - 2);
}
console.time("fb执行时间2");
var result = fb(43);
console.timeEnd("fb执行时间2");
self.postMessage("worker2");
// 在worker里self相当于global/window全局变量

worker3.js

//   斐波那契数列,模拟一个很耗时的计算过程
function fb(n) {
  if (n == 1 || n == 2) {
    return 1;
  }
  return fb(n - 1) + fb(n - 2);
}
console.time("fb执行时间3");
var result = fb(43);
console.timeEnd("fb执行时间3");
self.postMessage("worker3");
// 在worker里self相当于global/window全局变量

运行结果在终端输入live-server(提前安装live-server: npm install live-serve -g)

页面如下

点击test.html,等待5秒左右就看到了

耗时比不开启webworker的要快三倍,是因为这里开启了三个webWorker,如果你电脑是2核的估计就体验不到了

右击电脑的固定栏

点击任务管理器

选择性能,这就是电脑的内核数。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1136383.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用Docker部署Apache Superset并实现公网远程访问

大数据可视化BI分析工具Apache Superset实现公网远程访问 文章目录 大数据可视化BI分析工具Apache Superset实现公网远程访问前言1. 使用Docker部署Apache Superset1.1 第一步安装docker 、docker compose1.2 克隆superset代码到本地并使用docker compose启动 2. 安装cpolar内网…

上帝视角看支付总架构解析

文章目录 1. 支付全局分层2. 交易服务层2.1 服务平台的支付架构2.2 架构的支付部分2.3 架构的清结算部分2.4 完整的架构 3. 支付服务层3.1 支付接收部分3.2 支付处理部分3.3 清结算部分 4. 清算服务层4.1 常见清算组织4.2 银联清算业务4.3 网联清算业务4.3.1 网联支持的业务4.3…

【Linux】 rpm安装包保存到本地并批量安装

目录 一、开启rpm安装包缓存到本地仓库 1. 修改yum.conf文件 2. 清理yum缓存 3. yum命令安装软件包 二、如何将rpm安装包保存到指定目录 方法一&#xff1a;yumdownloader 1. 安装yum-utils  2. yumdownloader命令参数说明 3. yumdownloader安装示例 方法二&#xff…

用Notepad++写java代码

步骤 1.新建&#xff0c;写代码 2.写好之后存为java文件 3.打开命令行 cd 对应位置 javac xxx.java &#xff08;如有中文&#xff09; java xxxdebug 1.错误: 编码utf-8的不可映射字符 这是代码里有中文&#xff0c;编译时加上-encoding utf-8即可 2.错误: 程序包xxx不存在…

ETO制造商目前面临的六大挑战,如何应对?

与离散制造、库存制造不同&#xff0c;按订单设计制造&#xff08;ETO&#xff09;行业面临着一系列独特的挑战。从复杂的产品设计到与客户的密切联系&#xff0c;按订单生产的每件产品都不尽相同。 如果采用按订单生产方式制造产品&#xff0c;管理者总是会想方设法采购最好的…

基于springboot实现书籍学习平台管理系统项目【项目源码+论文说明】

基于springboot实现书籍学习平台管理系统演示 摘要 首先,论文一开始便是清楚的论述了平台的研究内容。其次,剖析平台需求分析,弄明白“做什么”,分析包括业务分析和业务流程的分析以及用例分析,更进一步明确平台的需求。然后在明白了平台的需求基础上需要进一步地设计平台,主要…

礼品家居建材行业出口管理ERP解决方案

根据“一带一路”白皮书显示&#xff0c;2013至2022年&#xff0c;中国与共建国家进出口总额累计19.1万亿美元&#xff0c;年均增长6.4%&#xff1b;与共建国家双向投资累计超过3800亿美元。随着“一带一路”高质量共建&#xff0c;第134届广交会第二期打造的“大家居”主体概念…

Python教程:csv如何保存字典数据

下面是一个示例代码&#xff0c;它将字典数据保存到CSV文件中&#xff1a; #我的Python教程 #微信公众号&#xff1a;wdPython首先创建了一个包含字典数据的列表dict_data。然后&#xff0c;我们使用csv.DictWriter()函数创建一个CSV写入对象&#xff0c;指定了字典中的键作为…

智慧燃气,如何能够防患于未“燃”!

关键词&#xff1a;智慧燃气、智慧燃气建设、智慧燃气平台、智慧燃气系统、燃气数字化 天然气作为一种优质的清洁能源&#xff0c;在改善大气污染中起到非常重要的作用。国家也在将天然气发展成为我国主体能源之一。天然气的快速发展也给智慧燃气带来了光明的前途&#xff0c;…

【python】乱码的处理总结

Python 系列 如果你在Python中遇到了乱码问题&#xff0c;可能是由于字符编码不匹配导致的。以下是一些可能的解决方法&#xff1a; &#xff08;1&#xff09; 确认编码格式&#xff1a;首先要确认你的数据的实际编码格式。常见的编码格式包括UTF-8、GBK、GB2312等。确定正确…

goland无法调试问题解决

goland 无法调试问题解决 golang 版本升级后&#xff0c;goland 无法进行调试了 首先请看自己下载的版本是否有误 1.apple系 M系列芯片的 arm64版本 2.apple系 intel系列芯片的x86_64 3.windows系 intel解决如下&#xff1a; 查看gopath ericsanchezErics-Mac-mini gww-api…

一克商评|未来向外输出自动驾驶技术和解决方案的中国企业会越来越多

封面新闻记者 孟梅 欧阳宏宇 雷强 蔡世奇 付文超 小马智行获沙特新未来城1亿美元投资&#xff0c;并将成立合资公司 小马智行宣布获得沙特阿拉伯王国新未来城&#xff08;NEOM&#xff09;及旗下投资基金NIF&#xff08;NEOM Investment Fund&#xff09;的1亿美元投资。同时…

生成树协议:监控 STP 端口和交换机

什么是生成树协议 生成树协议 &#xff08;STP&#xff09; 用于网络交换机&#xff0c;以防止循环和广播风暴。在局域网 &#xff08;LAN&#xff09; 中&#xff0c;两条或多条冗余路径可以连接到同一网段。当交换机或网桥从所有可用端口传输帧时&#xff0c;这些帧开始在网…

金属纳米颗粒通过水基剥离方案使用嵌段共聚物模板

引言 随着纳米结构表面和界面在广泛的科学和技术应用中变得越来越重要&#xff0c;确定可扩展和廉价的方法来实现这些变成了一个关键的挑战。特别是有序、非密集、表面支撑的金属纳米颗粒的大面积阵列的制造&#xff0c;由于其在不同领域如等离子体增强薄膜太阳能电池中的应用…

基于java+springboot的人事招聘信息网站

运行环境 开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven 项目介绍 开发过程…

RK3588使用npu运行onnx模型推理

文章目录 前言1.安装rknn-toolkit22.将onnx模型转为rknn模型3.通过rknpu2加载rknn模型执行推理 前言 先说总体流程&#xff1a; 1.在x86主机上安装【rknn-toolkit2】 2.使用【rknn-toolkit2】&#xff0c;把onnx模型转换成rknn格式的模型。 3.在板子部署【rknpu2】&#xff0c…

2023年【北京市安全员-A证】考试及北京市安全员-A证考试内容

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 北京市安全员-A证考试根据新北京市安全员-A证考试大纲要求&#xff0c;安全生产模拟考试一点通将北京市安全员-A证模拟考试试题进行汇编&#xff0c;组成一套北京市安全员-A证全真模拟考试试题&#xff0c;学员可通过…

内网穿透的应用-Linux JumpServer堡垒机:安全远程访问解决方案

文章目录 前言1. 安装Jump server2. 本地访问jump server3. 安装 cpolar内网穿透软件4. 配置Jump server公网访问地址5. 公网远程访问Jump server6. 固定Jump server公网地址 前言 JumpServer 是广受欢迎的开源堡垒机&#xff0c;是符合 4A 规范的专业运维安全审计系统。JumpS…

快速掌握linux性能监控的相关命令及工具

在linux系统环境的测试开发过程中&#xff0c;我们常常需要评估系统性能&#xff0c;尤其在性能测试工作中&#xff0c;我们需要通过系统资源的监控&#xff0c;从而分析定位系统的性能瓶颈。 首先&#xff0c;我们要知道从哪些维度来评估系统的性能好坏&#xff1a; CPU利用率…