一文搞懂JS系列(二)之JS內(nèi)存生命周期,棧內(nèi)存與堆內(nèi)存怜跑,深淺拷貝

寫在最前面:這是我即將開始寫的一個系列样勃,主要是在框架橫行的時代,雖然上班用的是框架性芬,但是對于面試峡眶,以及技術(shù)進(jìn)階,JS基礎(chǔ)知識的鋪墊是錦上添花植锉,也是不得不學(xué)習(xí)的一塊知識辫樱,雖然開汽車的不需要很懂汽車,只需要掌握汽車的常用功能即可俊庇。但是如果你懂汽車狮暑,那你也能更好地開車,同理暇赤。當(dāng)然心例,一篇文章也不會光光只講一個知識點,一般會將有關(guān)聯(lián)的知識點串聯(lián)起來鞋囊,一邊記錄自己的學(xué)習(xí)止后,一邊分享自己的學(xué)習(xí),互勉!如果可以的話译株,也請給我點個贊瓜喇,你的點贊也能讓我更加努力地更新!

概覽

  • 食用時間: 6-12分鐘
  • 難度: 中等歉糜,別跑乘寒,看完再走

系列目錄

JS內(nèi)存生命周期

  • 分配內(nèi)存

  • 內(nèi)存的讀與寫

  • 釋放內(nèi)存

棧內(nèi)存與堆內(nèi)存

JS數(shù)據(jù)類型

在講棧內(nèi)存與堆內(nèi)存之前,大家應(yīng)該都知道JS分為兩種數(shù)據(jù)類型:

  • 基本數(shù)據(jù)類型

String , Number , Boolean , null , undefined , Symbol (大小固定踊兜,體積輕量竿滨,相對簡單)

  • 引用數(shù)據(jù)類型

Object , Array , Function (大小不一定,占用空間較大捏境,相對復(fù)雜)

內(nèi)存存儲機(jī)制

var a=true;      //布爾型于游,基本數(shù)據(jù)類型
var b='jack';    //字符型,基本數(shù)據(jù)類型
var c=18;        //數(shù)值型垫言,基本數(shù)據(jù)類型
var d={name:'jack'};   //對象贰剥,引用數(shù)據(jù)類型
var d=[0,1,2,3,4,5];   //數(shù)組,引用數(shù)據(jù)類型

正是因為數(shù)據(jù)類型的不同骏掀,所以他們的存放方式也不同鸠澈,就和現(xiàn)實生活中窮人和富人的住所完全不一樣(扯遠(yuǎn)了)。我們先來看一張圖:

image

可以看到, a , b , c 都是基本數(shù)據(jù)類型截驮, de 都是引用數(shù)據(jù)類型笑陈,他們在存放方式上有著本質(zhì)性的區(qū)別,基本數(shù)據(jù)類型的值是存放在棧內(nèi)存中的葵袭,而引用數(shù)據(jù)類型的值是存放在堆內(nèi)存中的涵妥,棧內(nèi)存中僅僅存放著它在棧內(nèi)存中的引用(即它在堆內(nèi)存中的地址),就和它的名字一樣坡锡,引用數(shù)據(jù)類型

內(nèi)存訪問機(jī)制

上面講的是存儲蓬网,接下來說一下變量的訪問,基本數(shù)據(jù)類型可以直接從棧內(nèi)存中訪問變量的值鹉勒,而引用數(shù)據(jù)類型要先從棧內(nèi)存中找到它對應(yīng)的引用地址帆锋,再拿著這個引用地址,去堆內(nèi)存中查找禽额,才能拿到變量的值

深淺拷貝

  • 淺拷貝

上面已經(jīng)和大家說過了基本數(shù)據(jù)類型與引用數(shù)據(jù)類型在存儲上的不同锯厢,那么皮官,接下來說的這個深淺拷貝,想必大家也在面試題中經(jīng)常碰到实辑,老方式捺氢,先來看一段代碼

var name='jack';
var obj={
  age:24
};

var nameCopy=name;
var objCopy=obj;

nameCopy='bob';
objCopy.age=15;

console.log(name);    //jack
console.log(obj.age);     //15

你會發(fā)現(xiàn), name 是沒有被影響的剪撬,而我們命名是修改objCopy.age摄乒,為什么還會影響到 obj.age呢,這就是因為深淺拷貝的問題在搗鬼残黑,先來看下下面的一張圖

image

之所以會出現(xiàn)這種情況馍佑,是因為JS對于基本類型和引用類型的,當(dāng)我們在復(fù)制引用類型的時候梨水,復(fù)制的是該對象的引用地址挤茄,所以,在執(zhí)行 var objCopy=obj;的時候冰木,將 obj引用地址復(fù)制給了 objCopy,所以笼恰,這兩個對象實際指向的是同一個對象踊沸,即改變 objCopy 的同時也改變了 obj 的值,我們將這種情況稱為淺拷貝社证,僅僅復(fù)制了對象的引用逼龟,并沒有開辟新的內(nèi)存,拿人手短追葡,拷貝地太淺了腺律。(只有引用類型才會出現(xiàn)淺拷貝的情況)

  • 深拷貝

再來看接下來的一段代碼

var name='jack';
var obj={
  age:24
};

var nameCopy=name;
var objCopy=JSON.parse(JSON.stringify(obj));

nameCopy='bob';
objCopy.age=15;

console.log(name);    //jack
console.log(obj.age);     //24

可以發(fā)現(xiàn),在經(jīng)過 JSON.parse(JSON.stringify(obj)) 轉(zhuǎn)換了以后,淺拷貝不復(fù)存在宜肉,這一波是深拷貝匀钧,深拷貝開辟了新的堆內(nèi)存地址,并且將對象的引用指向了新開辟的內(nèi)存地址谬返,和前面復(fù)制的對象完全獨立之斯,自立根生,拷貝地很深遣铝,學(xué)功夫?qū)W到家佑刷,自立門戶的感覺。

  • 另外實現(xiàn)深拷貝的方法(更多方式請自行百度)

var objCopy=Object.assign({},obj);   //對象深拷貝的方法 Object.assign
var arrayCopy=array.concat();       //數(shù)組深拷貝的方法  concat()  (數(shù)組無嵌套對象或者數(shù)組可用)
var arrayCopy=array.slice();       //數(shù)組深拷貝的方法  slice()   (數(shù)組無嵌套對象或者數(shù)組可用)
JSON.parse(JSON.stringify(array))     //順帶提下酿炸,JSON.parse(JSON.stringify())   數(shù)組和對象通用

接著上面的數(shù)組容易踩坑的地方 瘫絮,來看一個例子

var array = [{name: 'jack'}, ['old']];
var arrCopy = array.concat();
arrCopy[0].name='new';
console.log(array); // [{name: 'new'}, ['old']]
console.log(arrCopy); // [{name: 'new'}, ['old']]

可以清楚地看到(數(shù)組無嵌套對象或者數(shù)組可用的情況下用 concatslice 才有效)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市填硕,隨后出現(xiàn)的幾起案子麦萤,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件频鉴,死亡現(xiàn)場離奇詭異栓辜,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)垛孔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進(jìn)店門藕甩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人周荐,你說我怎么就攤上這事狭莱。” “怎么了概作?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵腋妙,是天一觀的道長。 經(jīng)常有香客問我讯榕,道長骤素,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任愚屁,我火速辦了婚禮济竹,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘霎槐。我一直安慰自己送浊,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布丘跌。 她就那樣靜靜地躺著袭景,像睡著了一般。 火紅的嫁衣襯著肌膚如雪闭树。 梳的紋絲不亂的頭發(fā)上耸棒,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天,我揣著相機(jī)與錄音蔼啦,去河邊找鬼榆纽。 笑死,一個胖子當(dāng)著我的面吹牛捏肢,可吹牛的內(nèi)容都是我干的奈籽。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼鸵赫,長吁一口氣:“原來是場噩夢啊……” “哼衣屏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起辩棒,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤狼忱,失蹤者是張志新(化名)和其女友劉穎膨疏,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體钻弄,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡佃却,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了窘俺。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饲帅。...
    茶點故事閱讀 40,137評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖瘤泪,靈堂內(nèi)的尸體忽然破棺而出灶泵,到底是詐尸還是另有隱情,我是刑警寧澤对途,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布赦邻,位于F島的核電站,受9級特大地震影響实檀,放射性物質(zhì)發(fā)生泄漏惶洲。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一膳犹、第九天 我趴在偏房一處隱蔽的房頂上張望湃鹊。 院中可真熱鬧,春花似錦镣奋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至芯义,卻和暖如春哈垢,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背扛拨。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工耘分, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人绑警。 一個月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓求泰,卻偏偏與公主長得像,于是被迫代替她去往敵國和親计盒。 傳聞我的和親對象是個殘疾皇子渴频,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,086評論 2 355

推薦閱讀更多精彩內(nèi)容