• js的变量赋值的问题


    var a=xxx;

     xxx是基本数据,a中保存的是这个具体数据

    xxx是对象,a中保存的是对象的地址值 xxx={}  function

    xxx是一个变量,保存的是(基本数据,也有可能是对象数据-地址值)

    2、引用变量赋值问题,n个引用变量指向同一个对象,保存的内容都是对象内存的地址值

    1. var obj={name:"张三"}
    2. var obj2=obj;
    3. obj.name="JACK";
    4. console.log(obj2.name)//JACK

    将obj的内容保存到obj2,只是内容是地址值,通过一个变量修改对象内部数据,另一个变量看到的是修改之后的数据

    1. var obj1={name:'张三'};
    2. var obj2=obj1;
    3. obj2.age=12;
    4. console.log(obj1.age);//12
    5. function f(obj){
    6. obj.name='Bon'
    7. }
    8. f(obj1);
    9. console.log(obj2.name);//Bon
    1. var a={age:4};
    2. var b=a;
    3. a={name:'ss',age:34};//重新指向
    4. console.log(b.age,a.name,a.age)//4 ss 34
    1. var a={age:4};
    2. var b=a;
    3. a={name:'ss',age:34};//重新指向
    4. console.log(b.age,a.name,a.age)//4 ss 34
    5. function fn2(obj){
    6. //相当于 赋地址内容
    7. obj={age:15}//重新指向
    8. }
    9. fn2(a);
    10. console.log(a.age)//34

    3、在js调用函数时传递变量参数时,是值传递还是引用传递

    这里传递的是内容——》值 值传递

    1. var a = 3;
    2. function fn(a) {//传递的是var a=3
    3. a = a + 1;
    4. }
    5. fn(a)//传递的是3
    6. console.log(a)//3

    这里传递的是内容——》地址值  引用传递

    1. function f2(obj){
    2. console.log(obj.name)
    3. }
    4. var obj={name:'Tom'};
    5. f2(obj)//传递的是地址值Tom

    4、内存引擎如何管理内存

           1、内存生命周期

                    分配小内存空间(变量),得到它的使用权

                    存储数据,可以反复进行操作

                    释放内存:小内存空间

    全局变量:没有释放

            2、释放内存

                    局部变量:函数执行完自动释放

                    对象:成为垃圾对象,垃圾回收器回收

  • 相关阅读:
    快速理解python中的可迭代对象、迭代器、生成器
    面对新的测试框架不要慌看这里~
    ETCD数据库源码分析——etcd gRPC 服务 API
    Netty编程面试题
    Unity实现跨场景的传送门
    【纯虚函数,final/override关键字】
    C# 通过子窗体刷新父窗体:窗体控制
    网络安全与计算机网络基础知识
    文档管理系统对会计部门的重要性
    计算机组成原理_Cache的替换算法
  • 原文地址:https://blog.csdn.net/weixin_47295886/article/details/127653079