美文网首页
javascript异步编程

javascript异步编程

作者: 天字一等 | 来源:发表于2018-08-28 19:50 被阅读17次

    转载自:https://zhuanlan.zhihu.com/p/26567159

    分析事件循环流程前,先阐述两个概念,有助于理解事件循环:同步任务和异步任务。

    任务很好理解,JavaScript代码执行就是在完成任务,所谓任务就是一个函数或一个代码块,通常以功能或目的划分,比如完成一次加法计算,完成一次ajax请求;很自然的就分为同步任务和异步任务。同步任务是连续的,阻塞的;而异步任务则是不连续,非阻塞的,包含异步事件及其回调,当我们谈及执行异步任务时,通常指执行其回调函数。

    事件循环流程
    关于事件循环流程分解如下:

    宿主环境为JavaScript创建线程时,会创建堆(heap)和栈(stack),堆内存储JavaScript对象,栈内存储执行上下文;
    栈内执行上下文的同步任务按序执行,执行完即退栈,而当异步任务执行时,该异步任务进入等待状态(不入栈),同时通知线程:当触发该事件时(或该异步操作响应返回时),需向消息队列插入一个事件消息;
    当事件触发或响应返回时,线程向消息队列插入该事件消息(包含事件及回调);
    当栈内同步任务执行完毕后,线程从消息队列取出一个事件消息,其对应异步任务(函数)入栈,执行回调函数,如果未绑定回调,这个消息会被丢弃,执行完任务后退栈;
    当线程空闲(即执行栈清空)时继续拉取消息队列下一轮消息(next tick,事件循环流转一次称为一次tick)。

    关键知识点:
    1、并行:指在同一时刻,同时进行多个任务
    2、并发:指在同一时间段,多任务同时进行,但是在某一时刻,只执行一个任务
    3、堆
    4、栈
    5、消息队列(任务队列)
    6、同步任务和异步任务是同时进行,但是异步任务执行时不会进入执行栈,而是处在等待状态,同时通知线程:当出发该消息时需要向消息队列拆入一条消息,当同步任务执行完,线程从消息列队取出一条事件消息,其对应的异步任务入栈执行,

    事件循环流程
    关于事件循环流程分解如下:

    宿主环境为JavaScript创建线程时,会创建堆(heap)和栈(stack),堆内存储JavaScript对象,栈内存储执行上下文;
    栈内执行上下文的同步任务按序执行,执行完即退栈,而当异步任务执行时,该异步任务进入等待状态(不入栈),同时通知线程:当触发该事件时(或该异步操作响应返回时),需向消息队列插入一个事件消息;
    当事件触发或响应返回时,线程向消息队列插入该事件消息(包含事件及回调);
    当栈内同步任务执行完毕后,线程从消息队列取出一个事件消息,其对应异步任务(函数)入栈,执行回调函数,如果未绑定回调,这个消息会被丢弃,执行完任务后退栈;
    当线程空闲(即执行栈清空)时继续拉取消息队列下一轮消息(next tick,事件循环流转一次称为一次tick)。

    相关文章

      网友评论

          本文标题:javascript异步编程

          本文链接:https://www.haomeiwen.com/subject/czoqwftx.html