js变量、作用域和内存问题

更新日期: 2019-01-03阅读: 2.2k标签: 内存

1. 基本类型和引用类型的值

JavaScript变量可以用来保存两种类型的值:基本类性值和引用类性值。基本类性质源自以下5种基本数据类型:Undefined、Null、Boolean、Number和String。基本类型值和引用类性值有以下特点:

  1. 基本类型值在内存空间中占据固定大小的空间,因此会被保存在栈内存中;
  2. 从一个变量向另一个变量复制基本类型的值,会创建这个值的一个副本;
  3. 引用类型的值是对象,保存在堆内存中; 包含引用类型值的变量实际上包含的并不是对象本身,而是一个指向该对象的指针;
  4. 从一个变量向另一个变量复制引用类型的值,复制的其实是指针,因此两个变量最终都指向同一个对象
  5. 确定一个值是哪种基本类型可以使用typeof操作符,而确定一个值是哪种引用类型可以使用instanceof操作符。


2. 执行环境及作用域

所有变量(包括基本类型和引用类型)都存在于一个执行环境(也称为作用域)当中,这个执行环境决定了变量的生命周期,以及哪一部分代码可以访问其中的变量。以下是关于执行环境的几点总结:

  1. 执行环境有全局执行环境(也称全局环境)和函数执行环境之分;
  2. 每次进入一个新执行环境,都会创建一个用于搜索变量和函数的作用域链;
  3. 函数的局部环境变量不仅有权访问函数作用域中的变量,而且有权访问其包含(父)环境,乃至全局环境;
  4. 延长作用域链:有些语句可以在作用链的前端临时增加一个变量对象,该变量对象会在代码执行后被移除。具体来说就是当执行流进入下列任何一个语句时,作用域链就会得到加长:try-catch语句的catch块和with语句。这两个语句都会在作用域链的前端添加一个变量对象。对with来说,会将指定的对象添加到作用域链中。对catch语句来说,会创建一个新的变量对象。
  5. 全局环境只能访问在全局环境中定义的变量和函数,而不能直接访问局部环境中的任何数据;(如果局部环境中存在着同名标识符,就不会使用位于父环境中的标识符)
  6. 变量的执行环境有助于确定应该何时释放内存;


3. 垃圾收集

JavaScript是一门具有自动垃圾收集机制的编程语言,开发人员不必关心内存分配和回收问题。可以对JavaScript的垃圾收集例程做如下总结:

  1. 离开作用域的值将被自动标记为可以回收,因此将在垃圾收集期间被删除;
  2. "标记清除"是目前主流的垃圾收集算法。这种算法的思想是给当前不使用的值加上标记,然后再回收其内存;
  3. 另一种垃圾收集算法是“引用计数”,这种算法的思想是跟踪记录所有值被引用的次数。JavaScript引擎目前都不再使用这种算法;但在IE中访问非原生JavaScript对象(如dom元素)时,这种算法仍然可能会导致问题;
  4. 当代码中存在循环引用现象时,“引用计数”算法就会导致问题;
  5. 循环引用指的是的对象A中包含一个指向对象B的指针,而对象B中也包含一个指向对象A的引用;
    (1)解决办法:在不使用它们的时候手工断开原生JavaScript对象与DOM元素之间的连接
    myObject.element = null;
    element.someObject = null;
    (2)将变量设置为null意味着切断变量与它此前引用的值之间的连接。当垃圾收集器下次运行时,就会删除这 些值并回收它们所占的内存
  6. 解除变量的引用不仅有助于消除循环引用现象,而且对垃圾收集也有好处。为了确保有效地回收内存,应该及时解除不再使用的全局对象,全局对象属性以及循环引用变量的引用;
    (1)优化内存占用的最佳方式,就是为执行中的代码只保存必要的数据。一旦数据不再有用,最好通过将其设置为null来释放其引用——这个做法叫做解除引用
    (2)解除引用的真正作用是让值脱离执行环境,以便垃圾收集器下次运行时将其回收。


链接: https://fly63.com/article/detial/2229

JavaScript 内存管理和垃圾回收

JavaScript 的内存管理和垃圾回收,是个略生僻的话题,因为在JavaScript 中不显式执行内存操作,不过最好了解它如何工作。

js常见的内存泄漏及解决方法总汇

js具有自动回收垃圾的机制,即执行环境会负责管理程序执行中使用的内存。在C和C++等其他语言中,开发者的需要手动跟踪管理内存的使用情况。在编写js代码时候,开发人员不用再关心内存使用的问题,所需内存的分配 以及无用的回收完全实现了自动管理。

浅谈javaScript内存机制

javaScript内存空间并不是一个经常被提及的概念,想要对JS的理解更加深刻,就必须对内存空间有一个清晰的认:栈与堆、复杂数据类型与基本数据类型、引用数据类型与堆内存

js 把一个对象赋值给另一个对象会指向同一个内存地址

实际上并不是新建一个和原对象(数组也是对象)完全一样的对象,而是把原对象的内存地址直接复制给了另一个对象,也就是说两个对象都是指向同一个内存地址,所以实际上它们就是同一个对象。

php底层原理之垃圾回收机制

php垃圾回收机制,对于PHPer来说是一个不陌生但是又不是很熟悉的内容。那么php是怎么实现对不需要的内存进行回收的呢?首先还是需要了解下基础知识,便于垃圾回收原理内容的理解。

php中的内存管理

计算机的内存由操作系统进行管理,所以普通应用程序是无法直接对内存进行访问的。应用程序只能向操作系统申请内存,通常的应用也是这么做的,在需要的时候通过类似malloc之类的库函数 向操作系统申请内存。

原生JS与Jquery删除iframe并释放内存-IE

当项目以tab页签方式打开多个iframe窗口时,关闭tab页签同时也需要关闭iframe并释放内存资源,主要是针对IE浏览器。

闭包真的会导致内存泄漏?

今天遇到一个很有争议的问题,在这里分享一下,我相信对于即将面试前端的小伙伴会有帮助的。主要内容是围绕下边的问题展开的,文章涉及到的其他方面的知识点不展开叙述。

Web 应用的内存优化

随着 Web 应用复杂程度越来越高,以及 NodeJS 大规模投入生产环境,许多 Web 应用都会长时间运行, JavaScript 的内存管理显得更为重要。JavaScript 具备自动回收垃圾的机制

Js内存泄露

用户一般不会在一个 Web 页面停留比较久,即使有一点内存泄漏,重载页面内存也会跟着释放。而且浏览器也有自动回收内存的机制,所以我们前端其实并没有像 C、C++ 这类语言一样,特别关注内存泄漏的问题。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!