JS高级--数据、变量和内存(相关问题)

一、关于赋值与内存的问题

问题: var a = xxx ,a的内存中到底保存的是什么?

若 xxx 是基本数据,a的内存中保存的就是这个数据

若 xxx 是对象,a的内存中保存的是对象的地址值

若 xxx 是一个变量,保存的就是 xxx 的内存内容(可能是基本数据,也可能是地址值)

 

二、关于引用变量赋值问题

1、n个引用变量指向同一对象,通过一个变量修改对象内部数据,其他所有变量看到的是修改之后的数据

var obj1 = {
    name: 'Tom'
}
var obj2 = obj1  // obj2保存的是a的内容, a的内容是一个地址值,这个地址值指向的是对象
obj2.age = 12
console.log(obj1.age)  // 12

2、两个引用变量指向同一个对象,让其中一个引用变量指向另一个对象,另一个引用变量依然指向前一个对象

var a = {
    age: 12
}
var b = a
a = {
    name: 'Bob',
    age: 13
}
b.age = 14
console.log(b.age, a.age, a.name)  // 14 13 Bob


function fn2(obj2) {
    obj = {
       age: 15 
    }
}
fn2(a)  // 调用函数时,将实参赋予给形参,即obj = a
console.log(a.age)  // 13

问题:在JS调用函数传递变量参数时,是值传递还是引用传递?

理解一:都是值传递(基本值(基本数据)/ 地址值)

理解二:可能是值传递,也有可能是引用传递(传递的是变量值的地址值)

var a = 3
function fn(a) {
    a = a + 1
}
fn(a)
console.log(a)  // 3

三、JS引擎如何管理内存

1、内存生命周期

第一步:分配小内存空间,得到他的使用权

第二步:存储数据,可以反复进行操作

第三步:释放小内存空间

2、释放内存

局部变量:函数执行完成后自动释放

对象:成为垃圾对象,垃圾回收器回收

注意:全部变量档次运行不会释放

var a = 3
var obj = {}
// 一共有三个内存空间:a、obj、{}
var a = 3
var obj = {}
obj = null
// 一共有2个内存空间: a、obj
function fn() {
    var b = {}
}
fn()
// b是自动释放,b所指的对象是在后面某个时刻由垃圾回收器回收

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值