1.先介绍下数据类型有哪些:

基础数据类型包括:string,number,boolean,undefined,null

引用数据类型包含:Object,Array,Date

2.再来介绍下存储方式:

栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放。

堆(操作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。

基本类型存储的是值而复杂数据类型也叫引用类型存储的是对象的地址如0x00001而在栈中存的是变量数值和函数参数
堆中存的是对象和数组

3.最后结合图例具体说明:

1.基本数据类型的存储:

javascript存储数据 js怎么存储数据_赋值


**基本的数据类型存储在栈中,先将变量的声明在内存中的栈开辟一片空间值是undefined,后将值赋给这片空间,执行步骤:

  1. var num; //值是:undefined
  2. num = 10;
  3. var n;
  4. n = num;**
    先声明后赋值,当一个变量赋值的是另一个变量时,就会将那个变量的值赋给这个变量

当改变值时:

var a = 11;
var b = a;
a = 12;
console.log(a); //12  
console.log(b); //11 b的值不会随a的值得改变而改变

2.引用数据类型的存储:

javascript存储数据 js怎么存储数据_javascript存储数据_02

  1. 在堆中存储的是对象,栈存储的是对象的地址
  2. new关键字,会在堆中生成一个空对象
  3. 对象的诞生,地址也会生成

当改变值时:

var a = [1,2,3]
    var b = a
     a[0] = 9
    console.log(b);   //[9,2,3]

b的值随着a的值改变而改,因为他们指向同一个内存地址

3.实参和形参在内存中存储:

javascript存储数据 js怎么存储数据_赋值_03


在栈中声明,实参赋值后,给函数中的假参传递值