zoukankan      html  css  js  c++  java
  • 第4章--变量,作用域和内存问题 jquery

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

    解析器要分析赋给变量的值是基本类型值还是引用类型的值
    基本类型:undefined   null   boolean   number    string
    引用类型的值:保存在内存中的对象    在javascript中不允许直接访问内存中的位置,即不能直接访问或操作内存空间。操作对象时,实际上是操作对象的引用。
       1-1
    动态的属性
    可以给引用类型的对象添加属性和方法,不可以给基本类型的值添加属性
    例子:
    var p=new object();//引用
    p.name="mao";
    var p2="jiben";//基本
    p2.name="mao2"
    alert(p.name);//mao
    alert(p2.name);//undefined
    . 1-2  复制变量的值
            基本类型是完全复制出一个副本
    引用类型 是复制出一个指针副本   两个指针指向同一个内存中的对象
    1-3   传递参数
    所有函数参数都是按值传递,访问变量则有按值和按引用类型两种方式
    基本类型的参数传递时,被传递的值(实参)会被复制给一个局部变量(形参即命名参数,也即arguments对象中的一个元素)。
    引用类型的参数传递时,形式参数获得的是值在内存中的地址。局部变量的变化反应在函数的外部。
    讲函数的参数想象成局部变量
    1-4   检测类型
    检测变量是否是基本数据类型   typeof操作符    如果变量的值是一个对象或null,则返回object
         检测变量是否给定引用类型的实例,instanceof操作符会返回true。如果使用instanceof检测基本类型的 值,则会返回false。
    例子:alert(person instanceof object);
     
    4.2   执行环境及作用域
    每个执行环境定义了变量获函数有权访问的其他数据,决定各自行为,都有一个与之关联的变量对象。环境中定义的变量和函数都保存在这个对象中,解析器会在后台使用此对象。
    web浏览器中,全局执行环境是window对象,所有全局变量和函数都是作为window对象的属性和方法创建的。该执行环境的所有代码执行完毕后,该环境被销毁。
           每个函数都有自己的执行环境,执行流进入一个函数,环境就会被推入到一个环境堆栈中。在函数执行完毕后,堆栈在将其弹出。将控制权返回给之前的执行环境。
    创建对象变量的一个作用域链scope chain,作用是保证执行环境有权访问的所有变量和函数的有序访问。
            作用域链的前端,是所在环境的变量对象,arguments对象(在全局环境中不存在)--->下一个包含环境---->再下一个包含环境....-------->一直到全局执行环境(始终是最后一个)。
    实例:
    var color="blue";//全局
    function changeColor(){
    if(color==="blue"){color="red";}
    else{color=“blue”;}
    }
    changeColor();
    alert("Color is now"+color);
     
           函数changeColor()的作用域链包含   自己的变量对象  arguments的对象   和全局环境的变量对象(如此才可访问全局的color变量)。
    实例2:
    在局部作用域中定义的变量可以在局部环境中域全局变量互换使用
    var color="blue";// 全局
    function changeColor(){
    var anotherColor="red";//局部1
    function swapColors(){
    var tempcolor=anothercolor;//局部2
    anothercolor=color;
    color=tempcolor;//当前环境下可以访问color   anothercolor和tempcolor
    }
    swapcolors(); //当前环境下可以访问anothercolor  和color
    }
    changecolor();//只能访问color
     
    在特定的执行环境中,内部环境可以通过作用域链访问所有的外部环境不能访问内部环境中的任何变量和函数。
    任何环境都不能通过向下搜索作用域链而执行环境。
    4.2.1延长作用域链
    环境的类型只有两种:局部和全局,但是也可有其他的方法来延长作用域。有些语句可以在作用域链的前端临时增加一个变量对象,该变量对象会在代码执行后被移除。两种情况
    1.try-catch语句中的catch块   创建一个新的变量对象,其中包含被抛出的错误对象的声明
    2.with语句    将语句中指定的对象添加到作用域链中。
    4.2.2没有块级作用域
    花括号括起来的部分就是块级,在c语言c++等高级语言中变量会在if语句或for语句的块内存在,当块语句执行完毕后,变量即被销毁。
    但是在javascript中,if语句中的变量声明会将变量添加到当前的执行环境当中。在例子中是全局环境,所以在接下来的语句中,变量仍然有效
    例子:
    if(true){
    var color="blue";
    }
    alert(color);//blue;
    例子2:
    for(var i=0;i<10;i++){dosomething(i);}
    alert(i);//10  当for语句结束后  定义的i变量仍然在全局环境内 所以  值一直有效。
    1.声明变量   使用var声明的变量会自动添加 到最接近的环境中。函数内部,最接近的环境就是函数的局部环境。
    如果初始化变量时,没有使用var声明,则变量会被自动添加到外部的执行环境中
      例子:
    function add(num1,num2){
    var sum=num1+num2;
    return sum;
    }
    var result=add(10,20);//30
    alert(sum);//弹出错误   当把sum前面的var去掉后,结果是30
    2.查询标识符
    当在某个环境中为了读取或写入而引用一个标示符时,必须通过搜索来确定该标示符实际代表什么。搜索过程从作用域链的前端开始,向上逐级查询给定名字匹配的标示符。搜索到就停止。
    例子:
    var color="blue";
    function getcolor(){
    return color;
    }
    alert (getcolor());//blue   如果在getcolor函数内部加入var color=“red”;值就会变为red 因为调用的是局部的变量离着最近。
    第4章--变量,作用域和内存问题 - 骡子 - stupidmule@126 的博客上图为第一种情况下的搜索示意图。
     
     很明显的变量的查询需要时间,访问局部变量要比访问全局变量更快。
    4.3垃圾收集
    javascript垃圾会自动收集,而非像c或c++那样需要程序员手工清除垃圾释放内存空间。
    垃圾收集器会按照固定的时间间隔周期性的执行。
    4.3.1标记清除   常用的方式,
    4.3.2引用计数  不常见
    4.3.3  性能问题  垃圾收集器的周期性运行   调整周期值
    4.3.4  管理内存     最有效的方法就是为执行中的代码只保存必要的数据。一旦数据不再游泳,最好通过将其值设置为null来释放其引用,此做法叫做解除引用。适合大多数全局变量和全局对象的属性。
    function createperson(name){
    var localperson=new object();
    localperson.name=name;
    return localperson;
    }
    var globalperson=createperson("nicholas");
    globalperson=null;//手工接触globalperson的引用
    解除引用的真正作用是让值脱离执行环境,以便垃圾收集器下次运行时将其回收。
  • 相关阅读:
    Sql Server 2005 遍历结果集方法之一
    WinForm 程序托盘及右键退出
    WinForm 程序托盘
    JavaScript 简单定时器原理
    利用Httphandler实现URL重写(重写URL及伪静态)
    CYSCode 生成ORM框架的属性代码
    WinForm开机启动 判断 设置
    同级元素,鼠标经过高亮,鼠标离开还原(除选中已高亮元素时),点击确定高亮
    JavaScript 获取地址栏参数值
    openssl aes 加解密
  • 原文地址:https://www.cnblogs.com/dongguolei/p/7902867.html
Copyright © 2011-2022 走看看