一、关于赋值与内存的问题
问题: 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所指的对象是在后面某个时刻由垃圾回收器回收