关于一些JS变量赋值在浏览器中的底层实现

浏览器栈内存

分享一些学习到的笔记

浏览器执行JS代码:

  1. 从电脑内存分配一块内存,执行代码(即栈内存 => Stack);
  2. 分配一个主线程自上而下执行JS代码

栈内存

栈内存又会分配出几个存储空间

  1. 变量存储空间
  2. 值存储空间
  3. 代码执行空间(主线程):
    1. 基本数据类型
      • 代码进栈执行
        • 例如let a = 1
        • 创建变量a放进当前栈内存变量存储区域
        • 创建一个值1,存储到栈内存值区域中(简单的基本类型,复杂的引用类型不是)
        • =为赋值,让变量和值相互关联
      • 执行完出栈,下一行代码进栈执行
      • 按值操作
    2. 引用数据类型
      • 代码进栈执行
        • 例如let a = {…}
        • 在内存中分配出一块新的内存,用来存储引用类型(堆内存 => heap)内存中有个16进制地址
        • 把键值对分别存储到堆内存中
        • 把堆内存地址放进值存储空间
        • 把堆内存地址和变量关联起来
      • 执行完出栈,下一行代码进栈执行
      • 按引用地址操作
          //浅拷贝,修改了同一个地址里面的值
          let a = {name:666};
          let b = a;
          b.n
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值