欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript內(nèi)存分配原理實(shí)例分析

 更新時(shí)間:2017年04月10日 12:00:52   作者:布瑞澤的童話  
這篇文章主要介紹了javascript內(nèi)存分配原理,結(jié)合實(shí)例形式分析了javascript原始值和引用值內(nèi)存分配的原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了javascript內(nèi)存分配原理。分享給大家供大家參考,具體如下:

JavaScript中的變量分為兩種,原始值和引用值。原始值指的是原始數(shù)據(jù)類型的值,比如undefined,null,number,string,boolean類型所表示的值。引用值指的是復(fù)合數(shù)據(jù)類型的值,即Object,Function,Array等。

原始值和引用值存儲(chǔ)在內(nèi)存中的位置分別為棧和堆。原始值是存儲(chǔ)在棧中的簡(jiǎn)單數(shù)據(jù)段,他們的值直接存儲(chǔ)在變量訪問(wèn)的位置。引用值是存儲(chǔ)在堆中的對(duì)象

存儲(chǔ)在棧中的值是一個(gè)指針,指向存儲(chǔ)在堆中的實(shí)際對(duì)象。

我們來(lái)看一段代碼:

function Person(id,name,age){
this.id = id;
this.name = name;
this.age = age;
}
var num = 10;
var bol = true;
var str = "abc";
var obj = new Object();
var arr = ['a','b','c'];
var person = new Person(100,"jxl",22);

再看看內(nèi)存分析圖:

由上圖可知我們無(wú)法直接操作存儲(chǔ)在堆中的數(shù)據(jù),但是我們可以通過(guò)棧中的引用來(lái)操作對(duì)象。那么為什么要分開(kāi)呢?不都是存儲(chǔ)在內(nèi)存中嗎?

棧的優(yōu)勢(shì)就是存取速度比堆要快,僅次于直接位于CPU中的寄存器,但缺點(diǎn)是,存在棧中的數(shù)據(jù)大小與生存期必須是確定的,缺乏靈活性。堆的優(yōu)勢(shì)是可以動(dòng)態(tài)地分配內(nèi)存大小,生存期也不必事先告訴編譯器,垃圾收集器會(huì)自動(dòng)地收走這些不再使用的數(shù)據(jù),但是缺點(diǎn)是由于在運(yùn)行時(shí)動(dòng)態(tài)分配內(nèi)存,所以存取速度較慢。

所以相對(duì)于簡(jiǎn)單數(shù)據(jù)類型而言,他們占用內(nèi)存比較小,如果放在堆中,查找會(huì)浪費(fèi)很多時(shí)間,而把堆中的數(shù)據(jù)放入棧中也會(huì)影響棧的效率。比如對(duì)象和數(shù)組是可以無(wú)限拓展的,正好放在可以動(dòng)態(tài)分配大小的堆中。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論