zoukankan      html  css  js  c++  java
  • 值类型和引用类型的区别?

    JS的数据类型都有哪些?

    • 值类型(基本类型):字符串(String)、数字(Number)、布尔(Boolean)、空值(null)、未定义(undefined)、转义字符、Symbol(ES6引入了一种新的原始数据类型,表示独一无二的值)。

    • 引用数据类型:对象(Object)、数组(Array)、函数(Function)。

    值类型和引用类型的区别?

    (1) 存储位置不一样

    ① 值类型的变量会保存在栈内存中,如果在一个函数中声明一个值类型的变量,那么这个变量当函数执行结束之后会自动销毁

    ② 引用类型的变量名会保存在栈内存中,但是变量值会存储在堆内存中,引用类型的变量不会自动销毁,当没有引用变量引用它时,系统的垃圾回收机制会回收它

    栈内存堆内存
    a = 10,b = 20;  
    arr [10,20,30,40,50]

    (2) 复制方式不一样

    ① 值类型的变量直接赋值就是深复制,如 var a = 10; var b = a;那么a的值就复制给b了,b修改值不会影响a

    ② 引用类型的变量直接赋值实际上是传递引用,只是浅复制

    var arr = [10,20,30];
    var array = arr;
    array[0] = 1;
    console.log(arr,array);

    输出结果arr和array都会是[1,20,30],要想实现深复制,必须在堆内存中再开辟一块空间

    (3) 值类型无法添加属性和方法

    var per = "web";
    web.age = 10;
    web.eat = function(){
    console.log('eating');
    }
    console.log(web.age);
    console.log(web.eat);

    结果都会返回undefined

    (4) 引用类型可以添加属性和方法

    var per = {};
    per.age = 18;
    per.eat = function(){
    console.log("eated");
    }
    console.log(per.age);
    console.log(per.eat);

    结果person.age=18,person.eat返回一个函数

    (5) 值类型的比较是值的比较,只有当它们的值相等的时候它们才相等。比较的时候注意”==”和”===”,双等号(==)在做比较的时候做了类型转换,而全等号(===)是值和类型相等是才能相等

    var stu1 = '{}';
    var stu2 = '{}';
    console.log(stu1===stu2);

    结果返回true,两个相同字符串的比较,是值(‘{}’)的比较,完全相等

    (6)引用类型的比较是引用地址的比较

    var stu1 = {};
    var stu2 = {};
    console.log(stu1===stu2);

    结果返回false,两个空对象在堆内存中的地址不一样,所以即使两个一模一样的对象也不一定相等

  • 相关阅读:
    皇帝的用人之道,这一点古今皆同
    sharepoint打包
    powershellbegin
    taxonomy
    powershelluninstall webapplication
    面试题
    字符串处理
    在页面中插入视频时的文件夹命名问题
    process object
    扩展名显示与隐藏
  • 原文地址:https://www.cnblogs.com/hello9102/p/12726797.html
Copyright © 2011-2022 走看看