美文网首页
js运行机制

js运行机制

作者: JX灬君 | 来源:发表于2021-07-21 19:19 被阅读0次

Ecstack 执行环境栈
AO:活动对象(Activation Object)- 函数内部
EC:执行环境(Execution Context)执行上下文
VO:变量对象(Varibale Object)- 全局

js 从上往下执行

  1. Ecstack执行环境栈

  2. EC(Global) 全局执行上下文
    -Vo全局变量对象(入栈,压栈)
    (赋值操作分为三部分:创建值,创建变量,把值和变量进行关联)
    (基本类型存在栈里面,引用对象数据类型存在堆里面(函数也是引用对象类型))

  3. 函数堆(16进制的hash码值)
    (函数堆在对函数进行存储时,将函数体里的内容当成是字符串)
    (函数堆在对函数进行存储之前,初始化作用域(创建函数作用域[[scope]]))
    ([[scope]])作用域的产生一定是看函数执行上下文,执行上下文等同于函数作用域,也可理解为当前函数的执行上下文等于他的作用域)

  4. 每个函数执行都会开辟一个独立的执行上下文(=独立的执行空间)EC(A)
    (EC(A))私有的执行上下文
    (每次生成的私有执行上下文都会从上往下进行压栈)
    // js 函数内部存在变量提升

let a = 0, b = 0
function A(a) { 
      // 重新对A进行赋值
      A = function (b) {
        console.log(a + b++);
      }
      console.log(a++);
    }
    A(1)
    A(2)
// 结果:1  4
/**
     * ---一.将函数function A(a)存储在函数堆里,初始化一个16进制的hash码值地址:10X1A
     * --1.存储之前初始化作用域:[[scope]]:EC(G)
     * --2.内容存起来
     *      形参:a
     *      内容:"A = function (b) {
     *               console.log(a + b++);
     *            }
     *            console.log(a++);"
     * ---二.将函数function A(a)的函数堆地址:10X1A放到对应的EC(G)全局执行上下文里
     * ---三.作用域链:
     *      <EC(A),EC(G)>
     *      先从自己作用域看,没有往父级找
     * */

栈和堆

/**        堆
     * -----函数堆10X1A--start
     * ----------------------
     * -------------作用域:[[scope]]:EC(G)
     * 形参: a
     * 内容:"A = function (b) {
     *               console.log(a + b++);
     *            }
     *            console.log(a++);"
     * ----------------------
     * -----函数堆10X1A--end
     * 
     * -----函数堆20X2A--start
     * ----------------------
     * -------------作用域:[[scope]]:EC(A)
     * 形参: b
     * 内容:"console.log(a + b++);"
     * ----------------------
     * -----函数堆20X2A--end
     * */

    /**           栈
     * -------------Ecstack执行环境栈-start
     *------------------------------------
     * 
     * -----EC(A) 私有执行上下文-start
     * -----------------------------
     * AO活动变量对象-start
     * -------------------
     *        AO(A1)
     * -------------------
     * AO活动变量对象-end     
     * -----------------------------
     * -----EC(A) 私有执行上下文-end
     * 
     * -----EC(G) 全局执行上下文-start
     * -----------------------------
     * VO全局变量对象-start
     * -------------------
     *        A - 20X2A
     * -------------------
     * VO全局变量对象-end
     * 
     * 执行代码-start
     * -------------------
     *        A(1)
     *        A(2)
     * -------------------
     * 执行代码-end
     * ------------------------------
     * -----EC(G) 全局执行上下文-end
     *
     * ------------------------------------
     * ---------------Ecstack执行环境栈-end
     * */

相关文章

  • 最全js运行机制

    js运行机制

  • js new 运行机制

    js手札--js中new到底做了些啥JS核心系列:理解 new 的运行机制深入理解 Javascript 运行机制及原型

  • 浅析Vue.nextTick()原理

    1、为什么用Vue.nextTick() 首先来了解一下JS的运行机制。 JS运行机制(Event Loop) J...

  • 运行机制,宏任务 与 微任务

    运行机制: JS 的本质是单线程执行 事件队列:同步任务,异步任务() 运行机制 1,JS 的本质是单线程执行 单...

  • 前端知识点

    JS 1. 事件循环 「硬核JS」一次搞懂JS运行机制[https://juejin.cn/post/684490...

  • js运行机制

    js运行机制 在日常面试求职中,不免会做几道面试题,这面试题中往往会遇到js执行输出顺序,而这运行机制是我们每个前...

  • Event Loop

    关于浏览器的多进程,JS单线程等涉及浏览器整体运行机制、浏览器内核、JS运行机制,请看这篇文章,全是干货,什么时候...

  • JS的运行机制

    title: JS的运行机制date: 2018-12-28 11:02:52tags: js 为什么JavaSc...

  • JavaScript执行机制、Event Loop

    一、运行机制 JavaScript是单线程运行机制。 为什么JavaScript是单线程?单线程就是说,js在同一...

  • JS运行机制

    JS运行机制 如果一个文档流中包含多个script代码段(用script标签分隔的js代码或引入的js文件),运行...

网友评论

      本文标题:js运行机制

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