Js 运行机制剖析

作者 : 开心源码 本文共1367个字,预计阅读时间需要4分钟 发布时间: 2022-05-11 共77人阅读

”js是一门单线程的语言,js最大的特性是异步“,这些说法已经见惯不怪了,然而不理解js的解释执行始末,这些概念也就只是听听,真正遇到问题的时候,也只可以一脸懵逼而已~

一、Event Loop 机制/异步原理

Js 运行机制剖析

因为 Js 是一门单线程的语言,为了实现异步特性,必需有一种行之有效的机制,Event Loop 就是这种机制

说 Js 是一门单线程语言,指的是它只有一个使用户执行线程,同一时刻只可以执行一个任务,在你看不见的地方,还需要有很多其它线程/进程来调度

同步的情况

当程序开始运行的时候,将默认执行 全局执行上下文 (将在后文中说明)中的代码,假如遇到同步函数,那么将把当前 执行上下文 压入栈中,进入同步函数的 执行上下文 执行(倘若在函数中又遇到了其它同步函数,将持续此过程),当函数执行完成,执行线程将从消息线程中pop一个执行上下文 进行执行

Js 运行机制剖析

异步的情况

假如当前 执行上下文 遇到了异步操作,那么它向事件监听线程或者者计时线程发出通知之后,将继续执行,此时有两种情况:

a) 计时函数,如:

setTimeout(func, 1000);

此时,异步通知将发给计时线程(Timer),一秒后,计时线程将会把 func 函数的执行上下文压入消息线程堆栈,执行线程在解决完当前 执行上下文 的时候从消息线程堆栈中 Pop 出 func 的执行上下文 进行执行(假如在此期间没有别的 执行上下文 入栈的话)

所以, setTime(func, n); 并不可以保证,在 n 毫秒之后 func 可以被执行,这还得看执行线程当前在干什么了

b) 事件监听线程,假如发起的是一个异步io操作,如发起一个网络请求:

$.ajax(url, params, callback);

那么异步事件将发给事件监听线程去监听,一旦网络请求完成,同样的,事件监听线程将把 callback 的执行上下文入栈,等待执行线程的召唤

二、js的执行上下文

上文反复提到执行上下文,下面就对执行上下文进行一个深入剖析

如何了解执行上下文

所谓执行上下文,就是 Js 执行的时候的一个运行环境/作使用域(scope),有如下几种情况:

  1. 全局执行上下文/作使用域:js代码的默认执行环境(只有一个)

  2. 函数执行上下文/作使用域:每个函数对应的执行环境(无限多个)

  3. eval 代码执行上下文:用 eval 执行的脚步的执行环境

Js 运行机制剖析

全局作使用域中的方法、变量,能被其它任何函数作使用域所访问,函数作使用域中的方法变量,在子函数作使用域中能访问,外部无法直接访问

通过函数返回的子函数去访问函数作使用域的私有变量,也就形成了闭包

执行堆栈

也就是上文提到的 Event Loop,该线程以 的形式保存执行上下文,函数执行上下文的入栈出栈的过程,使得js得以在单线程的情况下,实现异步特性

执行上下文的创立与执行

每一次函数被调使用,js解释器都会为之创立新的上下文,此时能分为两个阶段:

a) 上下文的创立阶段:函数被调使用,但尚未开始执行(代码分析预解决阶段),此时会为执行上下文创立作使用域链,创立变量、函数和参数以及求this的值

Js 运行机制剖析

特别的,变量提升就是在这个阶段发生的

b) 执行阶段:指派变量的值和函数的引使用并解释执行代码

下面再使用伪代码的形式来形容一下这个过程:

Js 运行机制剖析

二、总结

理解 Js 解释器少量底层原理,是非常有必要的,当程序的运行结果跟你的预期结果不一样的时候,甚至看起来很诡异的时候,如何去解释,就很表现可以力了

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » Js 运行机制剖析

发表回复