JS基础——函数定义与函数调用内存分析

函数定义

1 在堆里开辟一块内存

2 函数的所有代码当作字符串存储在开辟的这块空间

3 把空间地址赋值给函数名(栈里面)

函数调用 fn()

1 通过函数名找到函数存储空间

2 在调用栈中再次开辟内存空间(函数执行空间)

3 在函数执行空间中进行形参复制、预解析

4 把函数存储空间代码复制一份到函数执行空间中进行依次执行

5 函数体代码全部执行完毕,函数的执行空间释放

/*
    函数定义:
    1 在堆里开辟一块内存
    2 函数的所有代码当做字符串存储在开辟的这块空间
    3 把空间地址赋值给函数名(栈里面)

    函数调用 fn()
    1 通过函数名找到函数存储空间
    2 在调用栈中再次开辟空间(函数执行空间)
    3 在函数执行空间中进行行参复制、预解析
    4 把函数存储空间的代码复制一份到函数执行空间中进行依次执行(依次执行函数体内的语句) 
    5 函数体代码全部执行完毕,函数的执行空间释放
*/
    function fn() {
       var a = 10;
       console.log('hello');
       console.log(++a);
    }
    fn(); // hello  11
    fn(); // hello  11

执行空间不被释放的情况

当函数的返回值是一个引用类型,并且外部还有变量在访问,此时函数执行空间不会被释放

/*
	当函数的返回值是一个引用类型,并且外部还有变量在访问,此时函数执行空间不会被释放
*/
function fn() {
   var a = 10;
   console.log('hello');
   console.log(++a);
   return {};
}
var obj = fn();
var obj1 = fn();
console.log(obj) // {}
console.log(obj === obj1) // false

posted @ 2021-04-13 14:42  春燕啄春泥  阅读(536)  评论(0编辑  收藏  举报