JavaScript - 变量、作用域和内存问题

变量:

1、基本类型

指简单的数据段,源自以下5种:

基本类型值在内存中占据固定大小的空间,因此被保存在栈内存中

  • Undefined
  • Null
  • Boolean
  • Number
  • String

提示:不允许给基本类型添加属性(尽管这样做不会导致任何错误):

var name = ‘Bert’;
name.age = 27;
alert(name.age); //undefined

<span>

Paste_Image.png

</span>

说明:只能给引用类型值动态地添加属性,以便将来使用。

var num1 = 5; var num2 = num1;

num1中保存的值是5。当使用num1的值来初始化num2是,num2中也保存了值5.但num2中的5与num1中的5是完全独立的,该值知识num1中5的一个副本。

基本类型的赋值是拷贝一份副本给另一个变量,两个变量参与任何操作不会相互影响。

2、引用类型

指那些可能由多个值构成的对象

注意:引用类型的值是保存在内存中的对象。与其他语言不同,JavaScript不允许直接访问内存中的位置,也就是说不能直接操作对象的内存空间。在操作对象时,实际上是在操作对象的引用(内存地址)而不是实际的对象。为此,引用类型的值是按引用访问的。

引用类型的赋值:

引用变量间的复制操作,也是将存储在变量对象中的值复制一份放到新变量中,不同的是这类值是指针(内存中的一段地址),这个指针指向存储在推中的一个对象。

复制操作结束后,两个变量实际上将引用同一个对象。因此,改变其中一个变量,就会影响另一个变量。

var obj1 = new Object();
var obk2 = obj1;
obj1.name = "Bert";
alert(obj2.name); // bert
Paste_Image.png

3、参数传递

ECMAScript中所有的函数的参数都是按值传递的。也就是说,把函数外部的值复制给函数内部的参数,就和把值从一个变量复制到另一个变量一样。

在向参数传递基本类型的值时,被传递的值会被复制给一个局部变量(即命名参数,或者用ECMAScript的概念来说,就是arguments对象中的一个元素)。

4、类型检测

typeof

typeof 操作符是确定一个变量是字符串、数值、布尔值、还是undefined的最佳工具。

如果变量的值是一个对象或null,则typeof操作符会像下面例子中所示的那样返回 object

var a = "Bert";
var b = true;
var c = 22;
var d;
var e = null;
var f = new Object();

alert(typeof a); // string
alert(typeof b); // boolean
alert(typeof c); // number
alert(typeof d); // undefined
alert(typeof e); // object
alert(typeof f); // object

instanceof

检测引用类型使用 instanceof 操作符

如果变量是引用类型(根据它的原型链来识别) instanceof 返回 true 或 false

alert(person instanceof Object); // 变量 person 是 Object 类型吗?
alert(colors instanceof Array); // 变量 colors 是 Array 类型吗?
alert(pattern instanceof RegExp); // 变量 pattern 是 RegExp 类型吗?

注意,匹配的对象首字母大写

5、执行环境及作用域

执行环境是JavaScript中最为重要的一个概念。(执行环境有全局执行环境和函数执行环境之分)

执行环境定义了变量或函数有权访问的其他数据,决定他们各自的行为。

每个执行环境都有一个与之关联的 变量对象,环境中定义的所有变量和函数都保存在这个对象中。

虽然我们编写的代码无法访问这个对象,单解析器在处理数据时会在后台使用它。

在 Web 浏览器中,全局执行环境被认为是window对象(全局执行环境值到应用程序退出,例如关闭网页或浏览器时才会被销毁)

函数(执行环境)

每个函数第一页租户的 执行环境。 当执行流进入一个函数时(执行一个函数),函数的环境就会被推入一个环境栈中。

在函数执行之后,栈将其环境弹出,把控制权返回给之前的执行环境。(假设之前的执行环境仍是一个函数,那么就会循环释放直至根环境)

作用域链

当代码在一个执行环境中执行时,会创建变量对象的一个 作用域链。作用域链的用途是保证对执行环境有权访问的所有变量和函数的有序访问。

那 this 和 作用域链 的关系如何解释?

作用域链的前端始终都是单签执行的代码所在环境的变量对象。

如果这个环境是函数,则将其 活动对象 作为变量对象。活动对象在最开始时只包含一个变量,即 arguments 对象(这个对象在全局环境中是不存在的)。

简单来说作用域链是一层一层从根至底的树形结构,底层可以访问顶层的数据,而顶层无法访问底层的数据(劳资我出生的时候怎么会知道自己将来会生几个儿子!! 放过来说做儿子的肯定知道自己的劳资是谁)

延长作用域链

  • try - catch 语句的 catch 块
  • with语句

这两个语句都会在作用域链的前端添加一个变量对象。

with:会将制定的对象添加到作用域链中。

catch:会创建一个新的变量对象,其中包含的是被抛出的错误对象声明。

没有块级作用域

JavaScript 没有块级作用。

  • 在if、for语句中声明的变量会被保存在当前执行环境中,在其执行结束时不会被销毁。
  • 不使用 var 声明的变量默认绑定到全局环境中。

6、垃圾回收、性能问题

在有的浏览器中可以出发垃圾收集过程(不建议使用)

  • 用 window.CollectGarbage()方法会立即执行垃圾收集。
  • 在Opera7及更高版本中,调用 window.opera.collect()也会启动垃圾收集例程。

有那么一点意思..

有垃圾回收机制的语言编写程序一般不必操心内存管理问题。

出于安全考虑,Web浏览器可用内存数量通常要少于桌面应用。因此,确保占用最少的内容可以让页面获得更好的性能。

优化内存占用的最佳方式,就是为执行中的代码只保存必要的数据。一旦数据不再有用,最好通过将其值设置为null来释放其引用 ---- 这个做法叫做 解除引用

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容