文章详情页
html5 - Javascript单线程中消息队列的执行疑问
问题描述
陆陆续续看了一些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. 引用 node.js express加载 静态文件 报错 ??2. javascript - 引入 simditor,但是显示标签,这个怎么解决。3. angular.js - ionic该如何强制刷新页面4. vue.js - weex 没有背景图片属性怎么办?5. 如何更新/删除指定的两条或多条数据6. 优先级的问题?7. node.js - 利用vue-cli 构建执行到npm run dev 报错,求解~8. 搭建一个用户间相互博弈的网站9. mysql_replication - mysql读写分离时如果单台写库也无法满足性能怎么解决10. mysql 一个sql 返回多个总数
排行榜