zoukankan      html  css  js  c++  java
  • JavaScript的变量、作用域和内存问题

    主要内容:

    • 理解基本类型和引用类型的值
    • 理解执行环境
    • 理解垃圾收集

    4.1 基本类型和引用类型的值

    基本类型值指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象。在将一个值赋给变量时,解析器必须确定这个值是基本类型值还是引用类型值。

    4.1.1 动态的属性

    对于引用类型的值,我们可以为其添加属性和方法,也可以改变和删除其属性和方法。

    4.1.2 复制变量值

       var num1=5;

       var num2=num1;

       num1 与num2中的5分别保存,相互独立。

       var obj1=new Object();

       var obj2=obj1;

       obj1.name="Hello";

       alert(obj2.name);//"Helo"

       obj1,obj2为同一Object对象的应用。

     4.1.3 传递参数

        ECMAScript中所有函数的参数都是按值传递的。

    4.1.4 检测类型

    检测一个基本数据类型的变量,typeof是最好的工具。typeof操作符是确定一个变量是字符串、数值、布尔值、还是undefined的最好工具。例如:

    var s="Hello";

    var i=25;

    var b=true;

    var u;

    var n=null;

    var o=new Object();

    alert(typeof s); //string

    alert(typeof i); //number

    alert(typeof b);//boolean

    alert(typeof u);//undefined

    alert(typeof o);//object

    alert(typeof n);//object

    检测一个引用类型的变量,我们更多的是想知道它是什么类型的对象。为此ECMAScript提供了instanceof操作符。语法格式:

    result=variable instanceof constructor

    alert(person instanceof Object);//变量person是Object吗?

    alert(colors instanceof Array);

    alert(pattern instanceof RegExp);

    4.2 执行环境

    执行环境是JavaScript中最为重要的一个概念。执行环境定义了变量或函数有权访问的其它数据,决定了它们各自的行为。每个执行环境都有一个与之关联的变量对象。环境中定义的所有变量和函数都保存在这个对象中。虽然我们编写的代码无法访问它,但解析器在处理数据时会在后台使用它。

    在Web浏览器中,全局执行环境被认为是window对象。每个函数都有一个执行环境。当代码在一个环境中执行时,会创建变量对象的一个作用域链。作用域链的用途,是保证对执行环境有权访问的所有变量和函数的有序访问。

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

    执行环境有全局执行环境和函数执行环境之分;

    每次进入一个新执行环境,都会创建一个用于搜索变量和函数的作用域链;

    4.3 垃圾收集

    JavaScript是一门具有自动垃圾收集机制的编程语言,开发人员不必关心内存分配和回收问题。"标记清除"是目前主流的垃圾收集算法,这种算法的思想是给当前不使用的值加上标记,然后再回收其内存。解除变量的引用不仅有助于消除循环应用现象,而且对垃圾收集也有好处。为了确保有效的回收内存,应该及时解除不再使用的全局对象、全局对象属性以及循环引用变量的引用。

      

  • 相关阅读:
    ORACLE备份脚本(4-RMAN1级增量备份)
    ORACLE备份脚本(3-RMAN0级全备)
    解决oracle数据库最大数据文件数超了
    ORACLE 数据库备份脚本(数据泵2-指定用户)
    oracle 数据库备份脚本(数据泵1-全库)
    Python操作hdfs
    ant实例
    Java网络编程客户端和服务器通信
    WordCount程序
    Python脚本开发练习
  • 原文地址:https://www.cnblogs.com/mazg/p/5405306.html
Copyright © 2011-2022 走看看