zoukankan      html  css  js  c++  java
  • javascript的内存分配

    了解javascript的人都知道数据的基本类型按大的分类有两种:原始值和引用值

      在研习算法的时候会过多的和内存打交道;理解栈和堆的定义是很重要的,算法就是为了能够获得最大的效率

      任何语言都是如此,javascript也不例外;在javascript中,我在把变量类型分为原始类型和引用类型。原始类型是放在栈即内存中,而引用类型这是放在堆中。在ECMAscript中,也是这么定义的。

      栈

      主要作用表现为一种数据结构,是只能在某一端插入和删除的特殊线性表。它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。

       栈是允许在同一端进行插入和删除操作的特殊线性表。允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,而栈顶 浮动;栈中元素个数为零时称为空栈。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为后进先出表。在这里用数组进行模拟栈的特性

      栈可以用来在函数调用的时候存储断点,做递归时要用到栈!

    var arr=[];//创建一个数组模拟栈
    arr.push("a");//压入元素a
    arr.push("b");//压入元素b
    arr.pop();//弹出元素a
    arr.pop();//弹出元素b
    arr.push("c");//压入元素c

     图谱解释:

     

    从上图可以看出栈有着先进后出的特性;在栈中的数据直接可以访问,效率比较高

      堆:

      在程序中,堆用于动态分配和释放程序所使用的对象。在以下情况中调用堆操作:

        1.事先不知道程序所需对象的数量和大小。

        2.对象太大,不适合使用堆栈分配器。

      堆使用运行期间分配给代码和堆栈以外的部分内存。

       在javascript中,引用数据是放在堆中的,例如数组和对象,因为在javascript中,一切都是对象,对象可以进行扩展,放置在堆中可以进 行不断的扩展,如果放在内存中就会消耗大量资源。放置在堆中的数据的查询效率比较低。这也是内存优于堆的好处,但是内存的存储空间要比堆的小很多。

    function Car(id,name,price)
    {
        this.id=id;
        this.name=name;
        this.price=price;
    }
    var num=24;
    var str="car";
    var bol=false;
    var obj={};
    var arr=[1,2,3];
    var car=new Car(1,"benze",230000);

     图谱解释:

    这样很清楚的知道栈和堆的区别;原始类型的数据放在栈中,引用类型的数据放在堆中。引用类型的数据同C中的指针很类似,我们不能直接操作堆中的数据,我们通过一个指针来引用这些数据进行操作,看以看作是远程操控。

        栈与堆的区别:

        1 效率的不同

          栈的效率比堆要高,栈中的数据直接可以使用,而对则需要通过引用来进行操作,即栈的速度比堆快

        2 空间存储不同

                     堆的存储空间要比栈大

               3 放置数据类型的不同

    原文:
    http://www.cnblogs.com/kycool/archive/2011/11/30/2268653.html
  • 相关阅读:
    ASP.NET中级学习3
    C#面向对象学习笔记
    Javascript学习笔记
    FormView控件使用
    ASP.NET初级学习
    ListView控件是使用
    Java NIO 学习笔记一
    堆栈和托管堆 c#
    安装php7.2并且整合nginx且分开部署
    Python 安装requests和MySQLdb
  • 原文地址:https://www.cnblogs.com/yuzhongwusan/p/2418964.html
Copyright © 2011-2022 走看看