资讯专栏INFORMATION COLUMN

谈谈值传递

awkj / 2205人阅读

摘要:以上的代码也可以写为这样在处,函数会将参数先声明并赋值,值就为下面传入的参数的值,的值为因此赋得值也为。

ECMAScript变量可能包含两种不同的数据类型:基本数据类型和引用数据类型,这两种类型的值传递是存在不同的.

在我们谈这两种数据类型的值传递前,为了便于理解,我想首先谈一下这两种数据类型有关复制操作存在的不同

数据类型的复制 基本类型
var num1 = 10;
var num2 = num1;
    num2 = 11;
console.log(num1);//10
console.log(num2);//11

基本数据类型从一个复制到另一个,会在变量对象上创建一个新值,然后把该值复制到新变量分配的位置上,改变其中一个不会影响另一个。

本小白用拙劣的画功演示一下

一开始声明变量num1并赋值为10,它便以图中的形式存在某种结构中,当用num1的值来初始化num2的时候,此时就相当于声明变量num2并赋值为num1中的值,该值只是num1中的一个副本,赋值结束,这两个变量便再无瓜葛,进行后面的操作也不会相互影响

引用类型

引用类型我们采用数组,数组的声明有两种方式,一种为var 数组名 = []另一种为var 数组名 = new array()

var arr1 = [1,2,3,4];
var arr2 = arr1;
    arr2[0] = 10;
console.log(arr1);//[10,2,3,4]
console.log(arr2);//[10,2,3,4]

此处及下文输出省略掉数组长度,可以看出输出的结果都为[10,2,3,4]. 和基本数据类型完全不同.

当声明数组变量并赋值的时候,同样也会存入一个结构当中,但是这个结构不能存[1,2,3,4]这种数据,要存到堆中去,就是图片右边那个椭圆形的区域,但是存入的数据还是要找到它。每个存储位置都有相应的地址,所以它在左边那个结构中存入的是一个指向数组对象的这样的一个地址。

当复制引用类型变量的时候,同样也会将存储在左边结构中的值复制一份放到为新变量分配的空间中去,只不过因为这个值的副本是一个指向堆中原数组对象的地址,两个变量名就相当于引用了同一个地址中的内容。因此,改变其中的一个变量,就会影响另一个

var arr3=[1,2,3,4];
var arr4=arr3;
arr4=[5,6,7,8];
console.log(arr3);//[1,2,3,4]
console.log(arr4);//[5,6,7,8]

这个相比于前面那个,只是在第三行代码中出现了不同,arr4=[5,6,7,8]将一个新的数组对象赋给变量arr4,这时arr4后的地址就改变了,也就指向了新的数组对象,这两个变量也就完全不相同了.

可以实验一下console.log(new Array(1,2)===new Array(1,2)),这个在控制台返回的是false

那好,现在有了这些铺垫,我们再来谈我们今天的主要内容.

数据类型的值传递 基本类型
var num = 10;

function change(num){
  num = 11;
  console.log(num);//11
}

change(num);
console.log(num);//10

在像参数传递基本类型的值时,被传递的值会被先复制给一个局部变量,其实就可以理解为基本数据类型的赋值。以上的代码也可以写为这样

var num = 10;

function change(){
  var num = 10;//look
  num = 11;
  console.log(num);//11
}

change(num);
console.log(num);//10

在look处,函数会将参数先声明并赋值,值就为下面传入的参数的值,num的值为10,因此赋得值也为10。但此时函数中的num和函数外部的num其实是毫不相关的,因此并不会相互影响

引用类型
var arr = [1,2,3,4];

function change(arr){
  arr[0] = 10;
  console.log(arr);//[10,2,3,4]
}

change(arr);
console.log(arr)//[10,2,3,4]

引用类型也如此,也可以理解为引用类型的复制操作,在函数的开头就会将arr赋值为传来的数值,虽然也是一开始声明的引用类型的副本,但是因为引用类型传来的数值是地址,因此函数中的arr和函数外面的arr都将引用同一个地址中的数组对象,因为arr指向的数组对象在堆中只有一个,又是全局变量,因此这两个arr是相同的,同样我们再看那一种声明数组并赋值的.

var arr=[1,2,3,4];

function change(arr) {
  arr=[4,5,6,7];
  console.log(arr);//[4,5,6,7]
}

change(arr);
console.log(arr);//[1,2,3,4]

那这个也就应该可以理解了,虽然在传参的时候传入的确实是一开始声明的数组对象的地址的副本,但是因为在函数内部又声明了一个新的数组对象,在这里arr引用的就是一个局部的数组对象了,而这个局部对象就会在函数结束后立即被销毁,不会影响函数外部的数组对象

本小白大二学生...自学前端一年,水平有限,就先解释这么多了,如果有不对的还请大佬们指点,本小白定当悔过自新,重新做人.

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/84330.html

相关文章

  • 谈谈我所理解的闭包,js、php、golang里的closure

    摘要:当初看这个解释有点懵逼,理解成闭包就是函数中的函数了。里的闭包最近不满足于只干前端的活,开始用起了。里的闭包最近在学习语言,让我们来看一下语言里的闭包。在中,闭包特指将函数作为值返回的情况,被返回的函数引用了生成它的母函数中的变量。 本人开始接触编程是从js开始的,当时网上很多人说闭包是难点,各种地方对闭包的解释也是千奇百怪。如今开始接触js以外的各种编程语言,发现不光是js,php、...

    betacat 评论0 收藏0
  • 谈谈我所理解的闭包,js、php、golang里的closure

    摘要:当初看这个解释有点懵逼,理解成闭包就是函数中的函数了。里的闭包最近不满足于只干前端的活,开始用起了。里的闭包最近在学习语言,让我们来看一下语言里的闭包。在中,闭包特指将函数作为值返回的情况,被返回的函数引用了生成它的母函数中的变量。 本人开始接触编程是从js开始的,当时网上很多人说闭包是难点,各种地方对闭包的解释也是千奇百怪。如今开始接触js以外的各种编程语言,发现不光是js,php、...

    zhoutao 评论0 收藏0
  • java基础之谈谈==和equals

    摘要:今天就来谈谈和的作用和区别。对于基础类型的作用就是判断值是否相等比如是是。就是重写了方法,所以出现了和结果不一致的情况。当然重写是有一定的标准的,如传递性,对称性等等,具体可以看源码要求不再一一展开。 判断对象是否相等是我们在项目中经常用到的,也是入门java必学的知识。今天就来谈谈==和equals的作用和区别。 1.==如何判断相等 先看一下一段代码: int ...

    Scorpion 评论0 收藏0
  • 从Mixin到hooks,谈谈对React16.7.0-alpha中即将引入的hooks的理解

    摘要:已经被废除,具体缺陷可以参考二为了解决的缺陷,第二种解决方案是高阶组件简称。我们定义了父组件,存在自身的,并且将自身的通过的方式传递给了子组件。返回一个标识该的变量,以及更新该的方法。   为了实现分离业务逻辑代码,实现组件内部相关业务逻辑的复用,在React的迭代中针对类组件中的代码复用依次发布了Mixin、HOC、Render props等几个方案。此外,针对函数组件,在Reac...

    ZweiZhao 评论0 收藏0
  • 从Mixin到hooks,谈谈对React16.7.0-alpha中即将引入的hooks的理解

    摘要:已经被废除,具体缺陷可以参考二为了解决的缺陷,第二种解决方案是高阶组件简称。我们定义了父组件,存在自身的,并且将自身的通过的方式传递给了子组件。返回一个标识该的变量,以及更新该的方法。   为了实现分离业务逻辑代码,实现组件内部相关业务逻辑的复用,在React的迭代中针对类组件中的代码复用依次发布了Mixin、HOC、Render props等几个方案。此外,针对函数组件,在Reac...

    funnyZhang 评论0 收藏0

发表评论

0条评论

awkj

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<