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给我们提供的便利。
相关文章推荐
- 用js实现跑马灯抽奖效果
- com.google.gson.JsonSyntaxException: 4.1.9
- JSP中播放提示声音
- jsp页面的js定时器的实现和关闭(不跳转页面)
- 使用Javascript实现客户端数据验证
- 7.2 Javascript:表单验证-提交表单
- 一个简单的ajax+servlert+jsp的完整实例
- JavaScript 弱类型浅谈
- ie7,ie8 js中变量名和页面元素ID重名,报错
- Json解析简单数据<二>
- JavaScript 闭包浅谈
- JSP生成验证码
- 使用JS制作弹出框的几个小问题
- 使用Gson解析json
- js实现图片预显示
- json
- js中SetInterval与setTimeout用法
- Js获取当前日期时间及其它操作
- #001 如何组织JS代码
- Js获取当前日期时间及其它操作