您的位置:首页 > Web前端 > JavaScript

JavaScript中变量的浅析

2016-03-15 13:27 537 查看

JavaScript中变量的浅析

脚本语言JavaScript中的变量与函数都不可以像C语言中的变量与函数那样理解。JavaScript向下隐藏了一些基本的概念与操作,向上扩张了很多新的理念与编程方法。

C语言中,我们姑且可以认为变量是内存一块区域的代号,每次为变量赋值都是向所代表的区域重新写入数据,参数在函数中的传递有复制传值和引用传值之分。但是在JavaScript中,我们可以认为一切变量都是指针,指向的是某一个对象。

(1)请看以下例子



输出b的结果是5,按C的理解也显然是这样的,然而这里以JavaScript的思维来理解更恰当。虽然我讲JavaScript中所有变量都是指针,这里b = a的执行使b与a指向了同一个对象,但b的输出并没有因为a = 6的改变而改变。可以理解为,在执行a = 6时,已经使a指向了另一个对象,即新构造的数字对象。

这样费力地理解一个不过脑子也能答对的问题,看似多此一举,其实是在为后面做铺垫。

(2)再看这个例子



输出b的结果是[4,2,3],遵循指针与对象的思维,很容易理解。b = a的执行使b与a指向同一个数组对象。a[0] = 4的赋值过程并没有改变a指针所指的对象,而是对这个对象的成员进行了修改,因为这里a与b始终指向同一个对象,所以这种修改对b的作用也是一样的。

(3)结合上面讲的,我们不妨来找个茬。如下例,设想a指向一个数组对象,b也指向这个对象的一个成员。当通过a来对这个成员进行修改时,b会怎么样呢?



答案是b的输出为1。这貌似和指针与对象的解释相悖,实则不然。a指向一个数组对象,当执行b = a[0]时,b显然没有指向这对象,其实也没有指向这个对象内的成员。因为a[0]并不是一个对象,而是对象内的成员,所以不能让对象指针b指向它,而是指向了根据这个成员构造的一个新的对象。

虽然这样细理解起来多绕了一个弯,其实平时我们在操作的时候,往往是直接这样对待的,否则编写程序的时候,要遇到很多意想不到的麻烦了。

(4)在编写JavaScript函数的时候,会联想到复制传值与引用传值的问题。有的文章讲,传数字或布尔值时,是复制传值,传数组或其它对象时,是引用传值。这样解释得通,但不够漂亮。看下面一个例子。



我们还是从指针与对象的角度思考。函数执行后,a与m,b与n分别指向同一个对象。m[0] = 5的执行修改了对象的成员,所以这个修改对a也是一样的。n = 6的执行使n指向了另一个对象,所以这种修改对b没有影响。

从指针与对象的角度思考,便很容易将上文提到的及其它问题一并理解。另外要注意到,这里的指针与C语言中的指针是有区别的。JavaScript中向下隐藏了指针操作的具体细节,对指针所指向的地址,与指针所指向的地址的内容,不做具体区分。C语言中指针操作有p与*p,而JavaScript中我们所看到的只有变量。通过上面的分析,已经认识到,JavaScript变量相当于指针p,对变量本身的各种赋值与修改,都是使它指向另一个对象。那么怎样操作对象本身,也就是C语言中的*p呢?因为JavaScript中,我们是涉及不到指针所指的地址的,所以直接用 变量.成员的形式访问操作,数值型和布尔型变量也是不必关心变量指针所指的地址,故也直接以变量的形式访问。这使得我们使用这种指针时有普通变量的直观感受,这也是JavaScript给我们提供的便利。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: