时间切片

1. 下次绘制交互 (INP)

  下次绘制交互 (INP) 是一项新的指标,浏览器计划于 2024 年 3 月将其取代取代首次输入延迟 (FID) ,成为最新的 Web Core Vitals(Web 核心性能指标)。

2. 时间切片-scheduler.yield

  背景:用户任务完成自动释放控制权给主线程。而如果任务耗时过长,则可能出现延迟导致主线程任务响应延迟。那么一种解决方法就是在主线程任务到来时将线程释放,先执行主线程任务,等主线程任务完成再继续执行该任务。这个理念最早在React的Schedule中实现,现在是浏览器要开始默认支持该功能。

  在没有时间切片概念之前,其他的处理方法:setTimeout。

 1 function blockingTask (ms = 200) {2   let arr = [];3   const blockingStart = performance.now();4 5   console.log(`Synthetic task running for ${ms} ms`);6 7   while (performance.now() < (blockingStart + ms)) {8     arr.push(Math.random() * performance.now / blockingStart / ms);9   }
10 }
11 
12 function yieldToMain () {
13   return new Promise(resolve => {
14     setTimeout(resolve, 0);
15   });
16 }
17 
18 async function runTaskQueueSetTimeout () {
19   if (typeof intervalId === "undefined") {
20     alert("Click the button to run blocking tasks periodically first.");
21     
22     return;
23   }
24   
25   clearTaskLog();
26 
27   for (const item of [1, 2, 3, 4, 5]) {
28     blockingTask();
29     logTask(`Processing loop item ${item}`);
30     
31     await yieldToMain();
32   }
33 }
34 
35 document.getElementById("setinterval").addEventListener("click", ({ target }) => {
36   clearTaskLog();
37 
38   intervalId = setInterval(() => {
39     if (taskOutputLines < MAX_TASK_OUTPUT_LINES) {
40       blockingTask();
41     
42       logTask("Ran blocking task via setInterval");
43     }
44   });
45   
46   target.setAttribute("disabled", true);
47 }, {
48   once: true
49 });
50 
51 document.getElementById("settimeout").addEventListener("click", () => {
52   runTaskQueueSetTimeout();
53 });

输出:

Processing loop item 1
Processing loop item 2
Ran blocking task via setInterval
Processing loop item 3
Ran blocking task via setInterval
Processing loop item 4
Ran blocking task via setInterval
Processing loop item 5
Ran blocking task via setInterval
Ran blocking task via setInterval

  使用scheduler.yield

方法:

 1 async function yieldy () {2   // Do some work...3   // ...4 5   // Yield!6   await scheduler.yield();7 8   // Do some more work...9   // ...
10 }

示例:

 1 async function runTaskQueueSchedulerDotYield () {2   if (typeof intervalId === "undefined") {3     alert("Click the button to run blocking tasks periodically first.");4     5     return;6   }7 8   if ("scheduler" in window && "yield" in scheduler) {9     clearTaskLog();
10 
11     for (const item of [1, 2, 3, 4, 5]) {
12       blockingTask();
13       logTask(`Processing loop item ${item}`);
14 
15       await scheduler.yield();
16     }
17   } else {
18     alert("scheduler.yield isn't available in this browser :(");
19   }
20 }

输出:

Processing loop item 1
Processing loop item 2
Processing loop item 3
Processing loop item 4
Processing loop item 5
Ran blocking task via setInterval
Ran blocking task via setInterval
Ran blocking task via setInterval
Ran blocking task via setInterval
Ran blocking task via setInterval

该特性在谷歌115版本才支持,兼容写法:

 1 function yieldToMain () {2   // Use scheduler.yield if it exists:3   if ('scheduler' in window && 'yield' in scheduler) {4     return scheduler.yield();5   }6 7   // Fall back to setTimeout:8   return new Promise(resolve => {9     setTimeout(resolve, 0);
10   });
11 }
12 
13 // Example usage:
14 async function doWork () {
15   // Do some work:
16   // ...
17 
18   await yieldToMain();
19 
20   // Do some other work:
21   // ...
22 }
Processing loop item  1 Processing loop item  2 Ran blocking task via setInterval Processing loop item  3 Ran blocking task via setInterval Processing loop item  4 Ran blocking task via setInterval Processing loop item  5 Ran blocking task via setInterval Ran blocking task via setInterval

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

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

相关文章

打怪(easy)

B-打怪(easy)_第二十届同济大学程序设计竞赛&#xff08;同步赛&#xff09; (nowcoder.com) 问题描述&#xff1a;初始攻击是1&#xff0c;防御是0&#xff0c;血量无穷。怪物防御力永远为0&#xff0c;只有初始血量和攻击力。双方每次受到的攻击会掉对手攻击-自己防御的血量…

[golang 流媒体在线直播系统] 1.直播的简单介绍以及借助腾讯云直播实现在线直播

一.直播的简单介绍 1.介绍 直播,应该不陌生,有电视直播、网络主播、游戏直播、体育直播、在线教育直播等等,那么要实现在线直播的话就 必须要有 “ 流媒体在线直播服务器 ”. “流媒体在线直播服务器 ”不仅可以 实现游戏、赛事、电商、媒体、教育等行业的直播, 还可以实现 …

java八股文面试[多线程]——并发三大特性 原子 可见 顺序

AutomicInteger : volatile CAS 总线LOCK MESI 两个协议 TODO volatile的可见性和禁止重排序是怎么实现的&#xff1a; DCL场景&#xff1a; new操作会在字节码层面生成两个步骤&#xff1a; 分配内存、调用构造器 然后把引用赋值给singleton 不加volatile则会发生指令重…

Docker从认识到实践再到底层原理(二-2)|Namespace+cgroups

前言 那么这里博主先安利一些干货满满的专栏了&#xff01; 首先是博主的高质量博客的汇总&#xff0c;这个专栏里面的博客&#xff0c;都是博主最最用心写的一部分&#xff0c;干货满满&#xff0c;希望对大家有帮助。 高质量博客汇总 然后就是博主最近最花时间的一个专栏…

ssm+vue乐购游戏商城系统源码和论文

ssmvue乐购游戏商城系统源码和论文115 开发工具&#xff1a;idea 数据库mysql5.7 数据库链接工具&#xff1a;navcat,小海豚等 技术&#xff1a;ssm 摘 要 随着社会的发展&#xff0c;游戏品种越来越多&#xff0c;计算机的优势和普及使得乐购游戏商城系统的开发成为必需…

mysql 表备份 遇到的问题 【全网最全】

目录 省流&#xff1a; 正文&#xff1a; 1、报错 2、原因 3、解决方法 方法一&#xff1a;关闭 ENFORCE_GTID_CONSISTENCY &#xff08;不推荐&#xff09;&#xff1a; 方法二&#xff08;推荐&#xff09;&#xff1a; 4、开启关闭GTID 省流&#xff1a; 不推荐如…

Databricks 入门之sql(二)常用函数

1.类型转换函数 使用CAST函数转换数据类型&#xff08;可以起别名&#xff09; SELECTrating,CAST(timeRecorded as timestamp) FROMmovieRatings; 支持的数据类型有&#xff1a; BIGINT、BINARY、BOOLEAN、DATE 、DECIMAL(p,s)、 DOUBLE、 FLOAT、 INT、 INTERVAL interva…

SpringBatch简述

前言 ​ 如今微服务架构应用增多&#xff0c;但在企业里还存在海量数据的批处理场景。诸如银行的金融机构中&#xff0c;每天有3-4万笔的批处理作业需要处理。而常见处理方案有&#xff1a; 1、数据脚本跑批 2、批处理框架 3、多线程事务处理方案。 ​ 在满足基本功能之外…

自智网络简介

网络随着业务和流量的发展&#xff0c;已经变的无比复杂&#xff0c;很难通过人力管理&#xff0c;因此业界提出了自智网络(自动驾驶网络)的概念。普林斯顿大学的Nick Feamster和Jennifer Rexford在本文中探讨了为什么网络需要自动化&#xff0c;以及达成这一目标的路径。原文:…

自制centos7.9的wsl发行版

自制centos7.9的wsl发行版 参考&#xff1a;https://zhuanlan.zhihu.com/p/482538727 Windows10提供了一个wsl工具用于直接在windows上运行Linux子系统。 CentOS国内镜像下载&#xff1a;https://mirrors.aliyun.com/centos/ 这里选择了7.9.2009版本&#xff1a;https://mirr…

android studio git没有显示Local Changes界面

设置android studio git没有显示Local Changes界面 Setting -> Version Control-> commit -> 把use non-modal commit interface 的勾勾去掉&#xff0c;如下图所示 然后点击apply&#xff0c;回到git界面就看到了&#xff0c;亲测有效

2023年7月京东护发市场数据分析(京东数据产品)

如今&#xff0c;与面部护肤相比&#xff0c;多数消费者认为头皮也需要认真对待&#xff0c;这在年轻消费群体中体现的较为明显。 随着消费者对护发理念的认同感不断加深&#xff0c;人们日常居家洗护的步骤也更加精细、使用产品品类也愈加多样化。除传统的护发素、发膜等护发…

Web3 社交平台如何脱颖而出?我们和 PoPP 聊了聊

能够颠覆 Web2 传统模式的社交产品有着怎样的特征&#xff1f;PoPP 作为专注于 Web3 的私域流量变现平台&#xff0c;为开发者和用户提供了社交产品发展的新路径&#xff0c;让社区用户充分实现互动交流&#xff0c;着力于创作内容的激励与变现。事实上&#xff0c;面对 Web3 社…

c语言自定义头文件是什么情况下使用?一般在什么情况下引用自定义的头文件?一般在自定义头文件中写什么代码?

c语言自定义头文件是什么情况下使用&#xff1f;一般在什么情况下引用自定义的头文件&#xff1f;一般在自定义头文件中写什么代码&#xff1f; C语言自定义头文件是一种用来封装函数和变量声明的文件&#xff0c;它通常用于将一组相关的函数和变量的声明集中在一个地方&#…

电脑可以上网,微信都可以用,但浏览器打不开网页

可以试试设置DNS&#xff08;其他windows版本步骤&#xff09;&#xff1a; 1.打开控制面板 2.网络和Internet 3.查看网络计算机和设备 4.按照下图步骤&#xff1a; 5.按下图进行

WorkPlus Meet支持企业局域网内部使用的视频会议系统

在当今飞速发展的数字时代&#xff0c;企业内部协作和沟通变得愈发多元化和重要。与此同时&#xff0c;随着数据泄露和信息安全风险的威胁不断升级&#xff0c;企业音视频沟通在各个业务场景中的广泛应用。为了提高工作效率&#xff0c;实现信息共享与协同办公&#xff0c;保证…

CSP的理解与绕过

文章目录 前言CSP简介CSP如何工作CSP指令CSP指令值 例题[AFCTF 2021]BABY_CSP 前言 刚学习完xss&#xff0c;把xsss-labs靶场都通了打算试试水&#xff0c;遇到此题[AFCTF 2021]BABY_CSP&#xff0c;借此机会学习下CSP CSP简介 Content Security Policy (CSP)内容安全策略&am…

c++之枚举

1、背景 在开发代码的过程中&#xff0c;vector类型数组a的index取了一个枚举值CTR&#xff0c;eg&#xff1a;a[CTR]&#xff0c;刚开始以为是map类型&#xff0c;后面看不是&#xff0c;简单的看了下c的enum类型&#xff0c;原来enum按顺序默认为数字。 2、enum简介 2.1、…

Spring与Mybatis整合aop整合pageHelper分页插件

前言 Spring与MyBatis整合的意义在于提供了一种结合优势的方式&#xff0c;以便更好地开发和管理持久层&#xff08;数据库访问&#xff09;代码。 这里也是总结了几点主要意义 简化配置&#xff1a;Spring与MyBatis整合后&#xff0c;可以通过Spring的配置文件来管理和配置M…

行业追踪,2023-08-31

自动复盘 2023-08-31 凡所有相&#xff0c;皆是虚妄。若见诸相非相&#xff0c;即见如来。 k 线图是最好的老师&#xff0c;每天持续发布板块的rps排名&#xff0c;追踪板块&#xff0c;板块来开仓&#xff0c;板块去清仓&#xff0c;丢弃自以为是的想法&#xff0c;板块去留让…