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

java做直播网站有哪些软件海南网站网络推广

java做直播网站有哪些软件,海南网站网络推广,几年做啥网站能致富,高端网站建设一般多少钱目录 简介微任务与宏任务的基本概念宏任务(Macrotasks)微任务(Microtasks)宏任务示例微任务示例微任务与宏任务的执行时序 结论 简介 在JavaScript的异步编程中,理解事件循环(Event Loop)是至关…

目录

    • 简介
    • 微任务与宏任务的基本概念
      • 宏任务(Macrotasks)
      • 微任务(Microtasks)
      • 宏任务示例
      • 微任务示例
      • 微任务与宏任务的执行时序
    • 结论

简介

在JavaScript的异步编程中,理解事件循环(Event Loop)是至关重要的。事件循环机制确保了JavaScript的单线程能够处理高并发的异步任务。
微任务(Microtasks)宏任务(Macrotasks)是事件循环中的两种主要任务类型。
本文将介绍这两种任务的区别,并通过代码示例深入探讨它们的工作机制,帮助您掌握前端异步编程的核心概念。

在这里插入图片描述

微任务与宏任务的基本概念

JavaScript的事件循环由任务队列组成,任务队列分为两种:微任务队列和宏任务队列每个宏任务执行完毕后,JavaScript引擎会先执行所有微任务队列中的任务,然后再执行下一个宏任务。

宏任务(Macrotasks)

宏任务通常指的是那些会在事件循环的单独迭代中执行的任务,它们包括:

  1. 整体脚本执行:整个JavaScript文件或脚本标签作为首次宏任务执行。
  2. setTimeoutsetInterval:设定的定时器到期后,会作为宏任务被添加到宏任务队列。
  3. setImmediate (Node.js 特有):在Node.js中,setImmediate用于在当前事件循环结束时执行。
  4. I/O:包括从网络、文件系统等进行的输入/输出操作。
  5. UI 渲染:浏览器将计算好的DOM更新渲染到屏幕上。
  6. requestAnimationFrame:用于动画的帧同步,会在下一次重绘之前执行。

微任务(Microtasks)

微任务在当前宏任务完成后立即执行,它们包括:

  1. Promise 回调Promise.then(), .catch(), 和 .finally() 方法。
  2. MutationObserver:用于监听DOM树变化的API,当DOM变化时触发。
  3. queueMicrotask:一个标准的API,允许开发者显式地将函数排入微任务队列。
  4. process.nextTick (Node.js):在Node.js中,process.nextTick 用于延迟函数的执行直到当前操作结束,但它会在当前执行栈清空之后,下一次事件循环之前执行。

宏任务示例

尽管setTimeout的延迟时间设置为0,它仍然是一个宏任务,会在当前宏任务执行完毕后,下一个事件循环迭代中执行。

console.log('Script start');setTimeout(function() {console.log('setTimeout');
}, 0);console.log('Script end');

输出:

Script start
Script end
setTimeout

微任务示例

Promisethen回调是微任务,它们会在当前宏任务的所有代码执行完毕后立即执行。

console.log('Script start');Promise.resolve().then(function() {console.log('promise1');
}).then(function() {console.log('promise2');
});console.log('Script end');

输出:

Script start
Script end
promise1
promise2

微任务与宏任务的执行时序

在这个示例中,我们可以看到Promise的微任务在当前宏任务的代码执行完毕后立即执行,而两个setTimeout的宏任务则在下一个事件循环迭代中执行。

console.log('Script start');setTimeout(function() {console.log('setTimeout');
});Promise.resolve().then(function() {console.log('promise1');
});setTimeout(function() {console.log('setTimeout2');
}, 0);console.log('Script end');

输出:

Script start
Script end
promise1
setTimeout2 (next event loop iteration)
setTimeout

结论

  • 微任务和宏任务是JavaScript异步编程的基石。
  • 微任务提供了一种更快的异步处理方式,通常用于快速连续的异步操作,而宏任务则包括了更广泛的异步事件。
http://www.zhongyajixie.com/news/48284.html

相关文章:

  • 优化wordpress访问速度优化网络搜索引擎
  • 自己做的网页可以上传网站吗网络营销的发展前景
  • 电商运营培训多少钱郑州官网网站推广优化公司
  • 智通人才东莞招聘网seo网站关键词优化工具
  • 微信如何做收费视频网站网站产品怎么优化
  • 公司主网站百度收录大量赌博之类的信息百度指数分析报告案例
  • app网站建设源码百度主页
  • 房产网站怎么做搜资源的搜索引擎
  • 惠州有做网站的吗百度云账号登录
  • 桃源县建设局网站推广手段
  • 郑州网站建设定制开发制作网站的软件
  • 京东b2c网站是怎么营销网站搭建教程
  • 网站建设与维护参考文献青岛网站排名公司
  • 收费网站开发苏州网站seo服务
  • 西宁专业做网站的站外推广方式
  • 誉重网站建设公司seo咨询顾问
  • 厦门 网站制作文案代写平台
  • python可以做网站后台吗东莞营销网站建设优化
  • 如何给网站写文章网站关键词排名seo
  • 广州网站优化工具服务移动惠生活app下载网址
  • 沈阳网站建设方案模板最靠谱的十大教育机构
  • 做网站什么字体沧州网站优化公司
  • 福建联泰建设集团网站网站seo诊断分析报告
  • 整容网站模板网络营销推广方案案例
  • 网站设计制作要多少钱郑州网站运营
  • 做网站菏泽如何做网站推广私人
  • 北京市保障性住房建设投资中心网站靠谱的影视后期培训班
  • 做网站原创要多少钱深圳网站做优化哪家公司好
  • 个人网站做百度竞价郑州网络营销推广公司
  • 怎么上传网站程序如何在百度上发广告