按值传递、按引用传递、按共享传递

  在看书上的传递参数时,看到说基本类型和引用类型在传递参数时都是按值传递的,特别是引用类型的传递参数,不是按引用传递的,又去网上查了一下关于引用类型的参数传递,发现了一个叫按共享传递的,看的很模糊,到底按值传递、按引用传递、按共享传递是什么,之间有什么区别,今天终于倒腾清楚了。

  首先,基本类型和引用类型在传递参数时都是按值传递的,在向参数传递基本类型的值时,被传递的值会被复制给一个局部变量(就是命名参数,arguments对象中的一个元素);在向参数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,因此这个局部变量的变化会反应在函数的外部。如下:

function addTen(num) {
    num += 10;
    return num;
}

var count = 20;
var result = addTen(count);
console.log(count + ' | ' + result); // 20 | 30

这是一个传递基本类型数据的例子。count=20作为参数传递给函数addTen中的参数num,相当于复制了一个新的num值也是20,count和num是独立的,它们之间互不认识,只是拥有相同的值。在函数中对num+10变成30,但是count的值还是20不会发生改变。

function setName(obj) {
    obj.name = 'aaa';
    var obj = new Object(); 
    obj.name = 'ccc';
    return obj;
}

var person = new Object();
person.name = 'bbb';
var newPerson = setName(person);
console.log(person.name + ' | ' + newPerson.name); // aaa | ccc

这是一个传递引用类型数据的例子。创建一个对象,赋值给变量person,并给其添加一个属性name,值为bbb,接着把person传递给了setName()函数中知乎就被复制给了obj,在这个函数内部,obj和person引用的同一个对象,换句话说,即使这个变量是按值传递的,obj也会按引用来访问同一个对象。在函数内部先把obj的name属性值改为aaa,接着又为obj定义了一个对象,该对象的name值为ccc,如果person是按引用传递的,那么person会被修改为指向name值为ccc的新对象,但是最终的结果显示person的name值还是aaa,说明即使在函数内部修改了参数的值,但原始的引用仍然保持未变。

看完上述例子,对于基本类型的按值传递,我理解了,但是引用类型的按值传递不是很理解,经查阅,引用类型的参数传递也可被称为按共享传递,下面就来说说这三种传递之间的区别:(以下述代码为例)

function foo(num,obj){
    ...
}
var num1=10,
var obj1={value:'hello'};
foo(num1,obj1);

这段代码反映在图上如下所示:

按值传递

函数内的num是一份新的内存,与调用函数之前定义的变量毫无关系。函数内无论怎么修改这个参数,外部定义的num1的值始终不变

传值的意思就是:传内存拷贝。

按引用传递

函数内的obj和定义的obj1会指向同一块内存,该内存就是调用函数之前定义这个变量时创建的内存。函数内对这个参数所做的任何改动,都将反映到外部定义的obj1变量上。

传引用的意思就是:传内存指针。

如果是按引用传递的话,是把第二格中的内容(也就是变量本身)整个传递进去(就不会有第四格的存在了)。

按共享传递

它的意思是:传引用的拷贝。
 
  变量obj1把它里面的值传递(复制)给了参数obj,让这个参数也指向原对象。因此如果在函数内部给这个参数obj赋值另一个对象时,这个参数就会更改它的值为新对象的内存地址指向新的对象,但此时原来的变量仍然指向原来的对象,这时候他们是相互独立的;但如果这个参数是改变对象内部的属性的话,这个改变会体现在外部,因为他们共同指向的这个对象被修改了!

  setName()中的 obj1是一个引用,他的内容是某块内存的地址,这个地址的值来自于外部定义的内存,是obj对象在内存中地址的一份拷贝,同时,在函数内部这个参数的值是可以直接被修改的,可以指向其他对象,但是obj是不会随着obj1的修改而指向其他对象的。

 

转载于:https://www.cnblogs.com/lmjZone/p/7977844.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值