var a=xxx;
xxx是基本数据,a中保存的是这个具体数据
xxx是对象,a中保存的是对象的地址值 xxx={} function
xxx是一个变量,保存的是(基本数据,也有可能是对象数据-地址值)
2、引用变量赋值问题,n个引用变量指向同一个对象,保存的内容都是对象内存的地址值
var obj={name:"张三"}
var obj2=obj;
obj.name="JACK";
console.log(obj2.name)//JACK
将obj的内容保存到obj2,只是内容是地址值,通过一个变量修改对象内部数据,另一个变量看到的是修改之后的数据
var obj1={name:'张三'};
var obj2=obj1;
obj2.age=12;
console.log(obj1.age);//12
function f(obj){
obj.name='Bon'
}
f(obj1);
console.log(obj2.name);//Bon
var a={age:4};
var b=a;
a={name:'ss',age:34};//重新指向
console.log(b.age,a.name,a.age)//4 ss 34
var a={age:4};
var b=a;
a={name:'ss',age:34};//重新指向
console.log(b.age,a.name,a.age)//4 ss 34
function fn2(obj){
//相当于 赋地址内容
obj={age:15}//重新指向
}
fn2(a);
console.log(a.age)//34
3、在js调用函数时传递变量参数时,是值传递还是引用传递
这里传递的是内容——》值 值传递
var a = 3;
function fn(a) {//传递的是var a=3
a = a + 1;
}
fn(a)//传递的是3
console.log(a)//3
这里传递的是内容——》地址值 引用传递
function f2(obj){
console.log(obj.name)
}
var obj={name:'Tom'};
f2(obj)//传递的是地址值Tom
4、内存引擎如何管理内存
1、内存生命周期
分配小内存空间(变量),得到它的使用权
存储数据,可以反复进行操作
释放内存:小内存空间
全局变量:没有释放
2、释放内存
局部变量:函数执行完自动释放
对象:成为垃圾对象,垃圾回收器回收