js的执行机制

本文探讨了JavaScript作为单线程语言如何处理任务执行,解释了同步任务和异步任务的概念。同步任务按照顺序执行,而异步任务通过WebWorker等机制在后台处理,避免阻塞主线程,提高页面性能。理解这两者对于优化JavaScript代码和提升用户体验至关重要。
摘要由CSDN通过智能技术生成

一、关于javascript
JS是一门单线程语言,这意味着所有的任务都需要排队,必须前一个任务做完 后一个任务才能执行。
这样所导致的问题是: 如果 JS 执行的时间过长,这样就会造成页面的渲染卡顿不流畅,导致页面渲染加载事件过长 闪屏 卡屏等情况。

二、同步任务和异步任务
单线程导致的问题就是后面的任务等待前面任务完成,如果前面任务很耗时(比如读取网络数据),后面任务不得不一直等待。
为了解决这个问题,利用多核 CPU 的计算能力,HTML5 提出 Web Worker 标准,允许 JS 脚本实现“多个线程”(JS是单线程这一核心仍未改变。所以一切"多线程"都是用单线程模拟出来的),但是子线程完全受主线程控制。于是,JS 中出现了同步任务和异步任务。

1.同步任务
同步任务:在主线程上排队执行的任务,只有前一个任务执行完毕,才能执行后一个任务。
比如有五个顾客来到了你的饭店,同步的做法是:先给第一个顾客点菜,然后做菜,结束后再给第二个人…以此类推。

2.异步任务
异步任务:不进入主线程、而进入”任务队列”的任务,当主线程中的任务运行完了,才会从”任务队列”取出异步任务放入主线程执行。
比如有五个顾客来到了你的饭店,异步的做法是:先给每一个顾客点菜,点完之后给他们一个牌子并把对应的菜单放到后厨然后让他们等待,之后后厨根据他们的菜单开始做菜。
 

3 执行顺序

先去执行同步任务 执行完再去执行异步任务。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值