专栏首页Web开发之路JavaScript 运行时环境

JavaScript 运行时环境

JavaScript 运行时环境

前言

每一个浏览器都有自己的 Js 运行时环境

AJAX、DOM树、以及其他的API,都是Javascript的一部分,它们本质上就是浏览器提供的、在JS运行时环境中可调用的、拥有一些列属性和方法的对象

除此之外,用来解析代码的 JavaScript 引擎也是位于 Js 运行时环境中的。后面以 Chrome V8 引擎来展开。

Js 运行时环境

运行时环境可以看作一个大容器,里面有很多小容器,当 Js 引擎去解析代码时,就是把代码片分布到不同的容器里。

  • Web Api 容器

调用栈中的 Web Api 调用会被分发到该容器里,比如事件监听函数、Http/Ajax 请求、或者是定时器,这些事件在该容器里直到达到触发条件,回调函数便会被推入回调队列里。

  • 回调队列

按照顺序添加所有的回调函数,等待执行栈为空则推送回调函数到执行栈栈顶。

  • 事件循环

持续监测回调队列和执行栈,监听 Web Api 容器是否满足执行条件满足则放到回调队列

  • 阻塞和非阻塞 I/O

当一个函数永远执行不完则会永远不会出栈,因此执行栈的下一个函数永远不会执行被阻塞。另一种情况就是当一个函数极其复杂耗时很长,也会阻塞下一个函数。

e.g. Http 请求执行完会被分发到 Web Api 容器等待回应,然后弹出栈,即使无法请求到数据不影响后续函数执行。所以,JavaScript 是一个非阻塞语言。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JavaScript 数据类型

    除了object其他都是基本类型,是的,null也是基本类型,但是有很多人把它当作对象类型,这其实是语言本身的一个bug。对null执行typeof null返...

    Karl Du
  • 提升

    到现在,我们已经明白作用域的概念了,以及根据声明的位置和方式将变量分配给作用域的相关原理。函数作用域和块作用域的行为是一样的,可以总结为:任何声明在某个作用域内...

    Karl Du
  • 你必须要知道的git rebase

    git add, git commit, git push, git stash, git pull, git merge, git log

    Karl Du
  • 强大的 IDEA 代码生成器,学会用,真香!

    Java 开发过程经常需要编写有固定格式的代码,例如说声明一个私有变量,logger或者bean等等。对于这种小范围的代码生成,我们可以利用 IDEA 提供的 ...

    用户5224393
  • 代码生成利器:IDEA 强大的 Live Templates!

    Java 开发过程经常需要编写有固定格式的代码,例如说声明一个私有变量,logger或者bean等等。对于这种小范围的代码生成,我们可以利用 IDEA 提供的 ...

    macrozheng
  • Python读书笔记18(初识自定义函数)

    在分享自定义函数之前,我们要弄明白什么是函数、方法。之前的教程我有刻意用方法和函数两种方式来称呼具体的内容。例如删除列表的某个元素! ? 方法是函数的一种,类中...

    用户1332619
  • 深入理解JavaScript函数 原

        从功能上理解,函数是一组可以随时运行的语句,是一段代码块,也是所谓的子程序。在JavaScript中,函数实质上也是一种对象,是Function对象。函...

    珲少
  • 微信也被监控:HackingTeam语音监控代码分析

    在HackingTeam泄漏的文件,我们发现了有针对主流聊天软件中的语音进行监控的代码,其中包括国内常用的微信。下面就以微信为例,来分析一下HackingTea...

    FB客服
  • 函数声明与表达式的区别

    HTML5学堂:函数有不同的定义方法,一种是函数声明,另一种是函数表达式,那么这两种有何区别呢? 函数声明的基本语法 function functionName...

    HTML5学堂
  • JavaScript 编程精解 中文第三版 三、函数

    ApacheCN_飞龙

扫码关注云+社区

领取腾讯云代金券