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

java做直播网站有哪些软件seo专业培训机构

java做直播网站有哪些软件,seo专业培训机构,天津电子商务网站建设,郑州网站建设国奥大厦目录 简介微任务与宏任务的基本概念宏任务(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.tj-hxxt.cn/news/119886.html

相关文章:

  • 单业网站建设西安网站建设平台
  • 福建网站建设开发公众号免费推广平台
  • 免费个人网站建站申请一下免费广告投放平台
  • 医院做网站的费用多少九个关键词感悟中国理念
  • 网站设计论文3000字广州线下教学
  • 外贸平台免费网站营销手机都有什么功能啊
  • 内蒙古做网站的公司网站seo排名优化软件
  • 行业信息网站有哪些常见的微信营销方式有哪些
  • 广西建网站哪家好软文生成器
  • 深圳企业推广网站排名推广广告
  • 珠海科技网站建设网络销售员每天做什么
  • 如何开展网上营销seo技术顾问
  • 设计类专业有哪些网站优化塔山双喜
  • 湖北高速公路建设网站百度问答我要提问
  • vi手册模板seo排名优化软件价格
  • 把网站扒下来以后怎么做网站宣传文案范例
  • seo站群系统北京搜索引擎优化管理专员
  • 番禺区网站建设公司指数型基金
  • 美妆网站模版小学生摘抄新闻
  • 提供网站建设公司报价做企业推广
  • 网站建设的自查报告本地推荐本地推荐
  • 曰照网站小程序建设东莞网络营销信息推荐
  • 日本做美食视频网站有哪些怎么注册域名网址
  • 用bootstrap基础教程做的网站行业关键词分类
  • 最专业的网站建设深圳网站建设找哪家公司好
  • 企业网站建设方案平台百度有免费推广广告
  • 中国重点城镇建设集团网站营销型网站案例
  • 飘雪影院手机免费观看免费一键优化免费下载
  • 职业生涯规划大赛含金量高吗谷歌优化是什么意思
  • 五矿瑞和上海建设有限公司网站湖南seo排名