javasctipt是一门单线程的非阻塞的脚本语言,单线程意味着,JavaScript

单线程意味着,javascript代码在执行的任何时候,都只有一个主线程来处理所有的任务。

JavaScript的事件分两种,宏任务(macro-task)微任务(micro-task)

宏任务:包括整体代码script,setTimeout,setInterval

微任务:Promise.then(非new Promise),process.nextTick(node中)

  • 事件的执行顺序,是先执行宏任务,然后执行微任务,这个是基础,任务可以有同步任务和异步任务,同步的进入主线程,异步的进入Event Table并注册函数,异步事件完成后,会将回调函数放入Event Queue中(宏任务和微任务是不同的Event Queue),同步任务执行完成后,会从Event Queue中读取事件放入主线程执行,回调函数中可能还会包含不同的任务,因此会循环执行上述操作。

举个例子

    setTimeout(

function()

{

console.log('setTimeout');

},1000)

new Promise(function(resolve)

{ console.log('promise');

}).then(

function() {

console.log('then');

})

console.log('console');

//2,4,3,1.

  • 先执行script同步代码

    先执行new Promise中的console.log(2),then后面的不执行属于微任务
    然后执行console.log(4)
  • 执行完script宏任务后,执行微任务,console.log(3),没有其他微任务了。
  • 执行另一个宏任务,定时器,console.log(1)。

最新文章

  1. windows命令
  2. 【读书笔记《Bootstrap 实战》】5.电子商务网站
  3. JAVA中的GC机制详解
  4. phpwind数据同步本地后登陆异常
  5. js设置radio选中
  6. 将文件放到Android模拟器的SD卡中的两种解决方法
  7. Azure 为 SAP 提供的增强监控解决方案
  8. javascript外部ファイル
  9. springmvc.xml或spring.xml 能运行配置文件总是出现错误
  10. 006-接收键盘的输入(read)
  11. SpannableString 给TextView添加不同的显示样式
  12. windows&lunix下node.js实现模板化生成word文件
  13. mybatis相关知识
  14. 近年NOIP考点与主要做法
  15. linux内核发生Oops时怎么办?
  16. 17秋 SDN课程 第三次上机作业
  17. [Asp.net mvc]国际化
  18. ExtJS梦想之旅(八)--GridPanel和EditorGridPanel的使用
  19. 解决 emoji表情存入数据库为' ??? '
  20. BeyondCompare

热门文章

  1. vue 的sync用法
  2. Django学习之路由系统
  3. Retina 屏幕与二倍图
  4. 《图解 CSS3 核心技术与案例实战》
  5. Jmeter之事物控制器
  6. Golang 调用 aws-sdk 操作 S3对象存储
  7. [Forward]C++ Properties - a Library Solution
  8. 转:高效实用的.NET开源项目
  9. 流程控制: if分支 while循环 for循环
  10. discover面试