• 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、释放内存

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

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

  • 相关阅读:
    我的创作纪念日—小梁说代码
    vs2012里面成功编译Notepad++源码
    ubuntu 查询mysql的用户名和密码 ubuntu查看username
    Spring Cloud Consul 从入门到精通
    Kubernetes原理剖析与实战应用手册,太全了
    pandas学习
    计算机毕业设计ssm计算机学院大学生实践指导系统lk43b系统+程序+源码+lw+远程部署
    Altium Designer
    【题解】PAT 1018 Public Bike Management
    nodejs模板引擎(一)
  • 原文地址:https://blog.csdn.net/weixin_47295886/article/details/127653079