普通类型与对象的区别

普通类型与对象的区别

简单类型:number, string, boolean, symbol, null, undefined ;
复杂类型:object ;

内存

  1. 一个 8G 的内存条
  2. 操作系统开机即占用 512MB
  3. Chrome 打开即占用 1G 内存
  4. Chrome 各每个网页分配一定数量的内存
  5. 这些内存要分给页面渲染器、网络模块、浏览器外壳和 JS 引擎(V8引擎)
  6. JS 引擎将内存分为代码区和数据区
  7. 本文只研究数据区
  8. 数据区分为 Stack(栈内存)和 Heap(堆内存)
  9. 简单类型的数据直接存在 Stack 里
  10. 复杂类型的数据是把 Heap 地址存在 Stack 里,遇到问题画内存图解决;

面试题解析:

var a = 1
var b = a
b = 2
请问 a 显示是几?  //1

内存图:

2.

var a = {name: 'a'}
var b = a
b = {name: 'b'}
请问现在 a.name 是多少?  //'a'

内存图:

3.

var a = {name: 'a'}
var b = a
b.name = 'b'
请问现在 a.name 是多少?  //'b'

内存图:


4.

var a = {name: 'a'}
var b = a
b = null
请问现在 a 是什么?  //{name:'a'}

内存图:

浏览器记下b的类型为null,不管后面存什么都为null。

5. 引用类型

var a = {n:1}
var b = a
a.x = a = {n:2}
alert(a.x);  ?  //undefined;
alert(b.x);  ?  //[object Object]
  • 先确定a为ADDR200,再确定a(ADDR100).x的值为ADDR200;
  • 建议写成(注意结果不同):
a ={n:2}
a.x = a

垃圾回收

  • 如果一个对象没有被引用,它就是垃圾,将被回收。

  • 图中function(){}不是垃圾,因为它被其它所引用。

深拷贝和浅拷贝

var a = 1
var b = a
b = 2
a = 1
  • b变化了没影响到a,为深拷贝
  • 一般赋值就用深拷贝;
var a = {name:'a'}
var b = a
b.name = 'b'
a.name = 'b'
  • b变化导致a变化,为浅拷贝
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

柴犬Clay

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值