zoukankan      html  css  js  c++  java
  • 值类型和引用类型的特征

     

    1. 值类型和引用类型的赋值

    1.1. 值类型赋值,直接将值复制一份

    var num1 = 10;
    var num2 = num1;
    

    上面两句代码,在内存中的体现为:

    • var num1 = 10;表示变量num1存储的是数字10
    • 将数据拷贝一份,也就是将10拷贝一份,这个时候内存中有两个10
    • 将拷贝的10赋值给num2

    1.2. 引用类型赋值,是将地址复制一份

    var p = {name:"张三", age:19};
    var p1 = p;
    

    上面两句代码,在内存中的体现为:

    • var p = {name:"张三", age:19};,p中存储的是对象的地址
    • 赋值就是将变量p中存储的数据,也就是地址拷贝一份, 然后将该数据赋值给p1
    • 此时内存中只有 1 个对象,变量pp1同时指向这个对象

    问题: 利用p1修改的name属性会影响到p中的name

    2. 值类型和引用类型做参数

    考虑如下情况:输出结果是多少?

    function foo(num){
        num++;
    }
    
    var a = 1;
    foo(a);
    console.log(a);
    

    继续考虑如下情况:输出结果是多少?

    function foo(o){
        o.age++;
    }
    
    var p = {name:"张三", age:19};
    
    foo(p);
    
    console.log(p.age);
    

    总结:

    • 在调用函数的时候,传参的过程其实就是用实参给形参赋值的过程

    • 当参数为值类型的时候,函数内和函数外的两个变量完全不同,仅仅只是存的值一样而已,修改时互不影响

    • 当参数为引用类型的时候,函数内和函数外的两个变量不同,但是共同指向同一个对象,在函数内修改对象数据时会影响外部

    扩展:

    考虑如下情况:输出结果是多少?

    
    function foo(o){
        o = {name:"张三", age:18};
    }
    
    var p;
    foo(p);
    
    console.log(p.age);
    猩猩爱宝贝儿
  • 相关阅读:
    win10+PHP 安装memcache
    win10+PHP 安装redis
    一个github搞定微信小程序支付系列
    Linux下新建一个站点
    Linux下更改mysql版本
    零基础配置Linux服务器环境
    手把手教你使用ueditor
    react学习三
    react学习二 生命周期
    window.location.replace和window.location.href区别
  • 原文地址:https://www.cnblogs.com/chengxuxing/p/7595901.html
Copyright © 2011-2022 走看看