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、释放内存
局部变量:函数执行完自动释放
对象:成为垃圾对象,垃圾回收器回收