博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深入理解 JavaScript中的变量、值、传参
阅读量:6612 次
发布时间:2019-06-24

本文共 2147 字,大约阅读时间需要 7 分钟。

图片描述

1. demo

如果你对下面的代码没有任何疑问就能自信的回答出输出的内容,那么本篇文章就不值得你浪费时间了。

var var1 = 1var var2 = truevar var3 = [1,2,3]var var4 = var3function test (var1, var3) {    var1 = 'changed'    var3[0] = 'changed'    var3 = 'changed'}test(var1, var3)console.log(var1, var2, var3, var4)

2. 深入理解原始类型

原始类型有5个 Undefinded, Null, Boolean, Number, String

2.1. 原始类型变量没有属性和方法

// 抬杠, 下面的length属性,toString方法怎么有属性和方法呢?var a = 'oooo'a.lengtha.toString

原始类型中,有三个特殊的引用类型Boolean, Number, String,在操作原始类型时,原始类型变量会转换成对应的基本包装类型变量去操作。参考JavaScript高级程序设计 5.6 基本包装类型。

所以说:在js中,也并不是一切都是对象

2.2. 原始类型值不可变

原始类型的变量的值是不可变的,只能给变量赋予新的值。

下面给出例子

// str1 开始的值是aaavar str1 = 'aaa'// 首先创建一个能容纳6个字符串的新字符串// 然后再这个字符串中填充 aaa和bbb// 最后销毁字符串 aaa和bbb// 而不能理解成在str1的值aaa后追加bbbstr1 = str1 + 'bbb'

其他原始类型的值也是不可变的, 例如数值类型的。

2.3. 原始类型值是字面量

3. 变量和值有什么区别?

  • 不是每一个值都有地址,但每一个变量有。《Go程序设计语言》
  • 变量没有类型,值有。变量可以用来保存任何类型的值。《You-Dont-Know-JS》

变量都是有内存地址的,变量有用来保存各种类型的值;不同类型的值,占用的空间不同。

var a = 1typeof a // 检测的不是变量a的类型,而是a的值1的类型

4. 变量访问有哪些方式?

变量访问的方式有两种:

  1. 按值访问
  2. 按引用访问

在JS中,五种基本类型Undefinded, Null, Boolean, Number, String是按照值访问的。基本类型变量的值就是字面上表示的值。而引用类型的值是指向该对象的指针,而指针可以理解为内存地址。

可以理解基本类型的变量的值,就是字面上写的数值。而引用类型的值则是一个内存地址。但是这个内存地址,对于程序来说,是透明不可见的。无论是Get还是Set都无法操作这个内存地址。

下面是个示意表格。

语句 变量 Get 访问类型
var a = 1 a 1 1 按值
var a = [] a 0x00000320 [] 按引用
抬杠
Undefinded, Null, Boolean, Number是基本类型可以理解,因为这些类型的变量所占用的内存空间都是大小固定的。但是
string类型的变量,字符串的长短都是不一样的,也就是说,字符串占用的内存空间大小是不固定的,为什么string被列为按值访问呢?

基本类型和引用类型的本质区别是,当这个变量被分配值时,它需要向操作系统申请内存资源,如果你向操作系统申请的内存空间的大小是固定的,那么就是基本类型,反之,则为引用类型。

5. 例子的解释

var var1 = 1var var2 = truevar var3 = [1,2,3]var var4 = var3function test (var1, var3) {    var1 = 'changed' // a    var3[0] = 'changed' // b    var3 = 'changed' // c}test(var1, var3)console.log(var1, var2, var3, var4)

上面的js分为两个调用栈,在

  • 图1 外层的调用栈。有四个变量v1、v2、v3、v4
  • 图2 调用test是传参,内层的v1、v3会屏蔽外层的v1、v3。内层的v1,v3和外层的v1、v3内存地址是不同的。内层v1和外层v1已经没有任何关系了,但是内层的v3和外层v3仍然指向同一个数组。
  • 图3 内层的v1的值被改变成'changed‘, v3[0]的值被改变为'changed'。
  • 图4 内层v3的值被重写为字符串changed, 彻底断了与外层v3联系。
  • 图5 当test执行完毕,内层的v1和v3将不会存在,ox75和ox76位置的内存空间也会被释放

最终的输出:

1 true ["changed", 2, 3] ["changed", 2, 3]

6. 如何深入学习JS、Node.js

看完两个stackoverflow上两个按照投票数量的榜单

如果学习有捷径的话,踩一遍别人踩过的坑,可能就是捷径。

7. 参考

  • 《JavaScript高级程序设计(第3版)》[美] 尼古拉斯·泽卡斯

转载地址:http://craso.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
20181219日志管理基础
查看>>
路由器的配置
查看>>
关于挂载的一些简单试验
查看>>
我的友情链接
查看>>
2015北京工业大学计算机考研复试学姐回忆
查看>>
LVM2逻辑卷之2——收缩功能介绍
查看>>
初识LVS(三)——DR工作模式实际环境中的应用
查看>>
验证码图片生成工具类——Captcha.java
查看>>
在Web上运行Linux
查看>>
11.11.19 v1 初次细看,ilab问题
查看>>
Ubuntu使用
查看>>
基于多线程的简单网络爬虫
查看>>
Linux防火墙SELinux和netfilter(工具iptables)
查看>>
tcpdump常用抓包命令
查看>>
Logstach配置文件详解
查看>>
VS设置文件的编码格式
查看>>
python爬虫抓取站长之家IP库,仅供练习用!
查看>>
Linux Rsync 服务配置
查看>>
英语学习方法笔记-20180711
查看>>