文章详情页
html5 - Javascript单线程中消息队列的执行疑问
浏览:141日期:2023-01-03 15:44:09
问题描述
陆陆续续看了一些js单线程,事件循环和消息队列的文章,但是有一个疑问是,当event loop消息队列的时候,假设里面有ajax和settimeout两个消息,当但是settimeout是先进入消息队列,ajax是后入,但是ajax先回馈结果了,settimout还没有,这个时候,event loop应该是先执行ajax吧?其实结合日常开发我也知道应该是这么回事,但是我看一些文章好像说异步消息队列也是按顺序轮询执行的,但是明明后面的比你先反馈,应该是先执行对把?
问题解答
回答1:ajax执行完,剩余事件进入 event loop. setTimeout 在延迟的时间结束时,将参数里的回掉放入event loop。
推荐你一个网站,在线掩饰event loophttp://latentflip.com/loupe
回答2:这个问题, 说起来比较长, 这里有篇文章, 很长但是建议深读. Ajax知识体系大梳理 | louis blog当然sf的专栏也是有的: Ajax知识体系大梳理 - 路易斯聊前端如果有不明白的地方, 直接文章底下给我留言就行.
回答3:按照我这两天看的情况,异步任务只有在完成相关触发条件才会被推入“任务队列”,等待主线程执行完同步任务按照先进先出的顺序执行“任务队列”中的任务。
标签:
JavaScript
相关文章:
1. docker 下面创建的IMAGE 他们的 ID 一样?这个是怎么回事????2. mysql 一个sql 返回多个总数3. docker-compose中volumes的问题4. 如何用笔记本上的apache做微信开发的服务器5. android - rxjava merge 返回Object对象数据如何缓存6. CSS3 画如下图形7. angular.js - ionic2 浏览器跨域问题8. python - Scrapy存在内存泄漏的问题。9. javascript - 蚂蚁金服里的react Modal方法,是怎么把元素插入到页面最后的10. css3 - 纯css实现点击特效
排行榜
