访问变量有按值和按引用两种方式,
基础数据类型按值访问,引用数据类型按引用(即指针或地址)访问。
但参数只能按值传递,
在向参数传递基本类型的值时,被传递的值会被复制给命名参数,引用类型时,传递的是它指针内存储的值
借用网上的一个例子
function setName(obj){
obj.name="nick";
console.log('第一次'+obj);
obj=new Object(); // 类似于obj = 2;
// 此处实例化一个新的对象或将obj = 2,即切断了它与原先地址的联系,拥有一个新的指针,这个对象为局部变量
// 只是这个obj和person的指针的值是一样的,但是两者是两个对象,对obj的操作并不会影响到person
console.log('第二次'+obj);
// 给这个新的对象添加属性
obj.name="greg";
console.log('第三次'+obj);
}
var person=new Object();
setName(person);
console.log('第四次'+person.name);
第一次nick
第二次undefined
第三次greg
第四次nick
由此可以证明是按值传递,若是按引用传递,则第三次和第四次应该结果一样,
一段时间过后,再次来看这个,发现写的有些问题:
例如:
var person = {
name:'tom',
sex:'max'
};
function changeName(obj){
// 此处并没有创建新的对象,即没有切断obj和person 的联系,即我们操作的就是原始的person的指针的值
obj.name = 'casy';
console.log(obj);
}
changeName(person);
// 打印出来的是{name: "casy", sex: "max"}
console.log(person);
// 此时打印出来的{name: "casy", sex: "max"}
因为操作的是同一个对象,所以两次打印的值一致