JS 基本數(shù)據(jù)類型和引用數(shù)據(jù)類型的區(qū)別及淺拷貝和深拷貝

JS基本數(shù)據(jù)類型和引用數(shù)據(jù)類型

再講 js 的基本數(shù)據(jù)類型和引用數(shù)據(jù)類型之前,我們先說一下棧和堆的概念

1呛占、棧(stack)和堆(heap)

  • 棧(stack):
    棧會自動分配內(nèi)存空間晌姚,會自動釋放屿储,存放基本類型鹊奖,簡單的數(shù)據(jù)段,占據(jù)固定大小的空間养篓。
  • 堆(heap):
    動態(tài)分配的內(nèi)存秃流,大小不定也不會自動釋放,存放引用類型柳弄,指那些可能由多個值構(gòu)成的對象舶胀,保存在堆內(nèi)存中,包含引用類型的變量碧注,實際上保存的不是變量本身嚣伐,而是指向該對象的指針。

2萍丐、基本數(shù)據(jù)類型和引用數(shù)據(jù)類型

基本數(shù)據(jù)類型Number轩端、StringBoolean碉纺、Null船万、 UndefinedSymbol(ES6)骨田,這些類型可以直接操作保存在變量中的實際值

基本數(shù)據(jù)類型特點:

  1. 占用空間固定,保存在棧中
    (當(dāng)一個方法執(zhí)行時声怔,每個方法都會建立自己的內(nèi)存棧态贤,在這個方法內(nèi)定義的變量將會逐個放入這塊棧內(nèi)存里,隨著方法的執(zhí)行結(jié)束醋火,
    這個方法的內(nèi)存棧也將自然銷毀了悠汽。因此箱吕,所有在方法中定義的變量都是放在棧內(nèi)存中的;棧中存儲的是基礎(chǔ)變量以及一些對象的引用變量柿冲,
    基礎(chǔ)變量的值是存儲在棧中茬高,而引用變量存儲在棧中的是指向堆中的數(shù)組或者對象的地址,這就是為何修改引用類型總會影響到其他指向這個地址
    的引用變量)

  2. 保存與復(fù)制的是值本身

  3. 使用typeof檢測數(shù)據(jù)的類型

  4. 基本類型數(shù)據(jù)是值類型

引用數(shù)據(jù)類型Object(在JS中除了基本數(shù)據(jù)類型以外的都是對象假抄,數(shù)據(jù)是對象怎栽,函數(shù)是對象,正則表達式是對象)

引用數(shù)據(jù)類型特點:

  1. 占用空間不固定宿饱,保存在堆中
    (當(dāng)我們在程序中創(chuàng)建一個對象時熏瞄,這個對象將被保存到運行時數(shù)據(jù)區(qū)中,以便反復(fù)利用(因為對象的創(chuàng)建成本通常較大)
    谬以,這個運行時數(shù)據(jù)區(qū)就是堆內(nèi)存强饮。堆內(nèi)存中的對象不會隨方法的結(jié)束而銷毀,即使方法結(jié)束后为黎,這個對象還可能被另一個引用變量所引用(方法的參數(shù)傳遞時很常見)邮丰,
    則這個對象依然不會被銷毀,只有當(dāng)一個對象沒有任何引用變量引用它時铭乾,系統(tǒng)的垃圾回收機制才會在核實的時候回收它剪廉。)

  2. 保存與復(fù)制的是指向?qū)ο蟮囊粋€指針

  3. 使用instanceof檢測數(shù)據(jù)類型

  4. 使用new()方法構(gòu)造出的對象是引用型

3、基本數(shù)據(jù)類型(Number片橡、String妈经、BooleanNull捧书、 Undefined吹泡、Symbol(ES6))存放在

  • 基本數(shù)據(jù)類型是指存放在棧中的簡單數(shù)據(jù)段,數(shù)據(jù)大小確定经瓷,內(nèi)存空間大小可以分配爆哑,它們是直接按值存放的,所以可以直接按值訪問
var a = 1;
var b = a;
b = 2;
console.log(a); // 1
console.log(b); // 2

棧內(nèi)存

在這里插入圖片描述

4舆吮、引用數(shù)據(jù)類型(Object)存放在

  • 引用類型是存放在堆內(nèi)存中的對象揭朝,變量其實是保存的在棧內(nèi)存中的一個指針(保存的是堆內(nèi)存中的引用地址),這個指針指向堆內(nèi)存
  • 引用類型數(shù)據(jù)在棧內(nèi)存中保存的實際上是對象在堆內(nèi)存中的引用地址色冀。通過這個引用地址可以快速查找到保存中堆內(nèi)存中的對象
  var a = {
    name: 'lily',
    age: '16'
  }

  var b = a;
  b.name = 'lokka';

  console.log(a); // {name: "lokka", age: "16"}

把 a 賦值給 b 潭袱,就相當(dāng)于把 a 的內(nèi)存地址指向 b ,即 a 和 b 指向同一內(nèi)存地址锋恬, 改變了 b 就相當(dāng)于改變了 a

在這里插入圖片描述

淺拷貝和深拷貝

1屯换、概念

淺拷貝:只拷貝一層,深層次的對象級別只拷貝引用。
深拷貝:拷貝多層彤悔,每一級別的數(shù)據(jù)都會被拷貝出來嘉抓。

2、淺拷貝的實現(xiàn)方式

  1. 方法一:通用循環(huán)
function shallowCopy(obj) {
  if (typeof obj !== 'object') return;

  const newObj = obj instanceof Array ? [] : {};

  for(let key in obj) {
    if (obj.hasOwnProperty(key)) {
      newObj[key] = obj[key];
    }
  }

  return newObj;
}
  1. 方法二:Object.assign
const newObj = Object.assign({}, oldObj);
  1. 方法三:Array.slice
const newArray = oldArray.slice();
  1. 方法四:Array.concat
const newArray = oldArray.concat();
  1. 方法五:es6
const { ...newObj } = oldObj;
const [ ...newArray ] = oldArray;

3晕窑、深拷貝的實現(xiàn)方式

  1. 方法一:通用循環(huán)
function deepCopy(obj) {
  if (typeof obj !== 'object') return;

  const newObj = obj instanceof Array ? [] : {};

  for(let key in obj) {
    if (obj.hasOwnProperty(key)) {
      newObj[key] = typeof obj === 'object' ? deepCopy(obj[key]) : obj[key];
    }
  }

  return newObj;
}
  1. 方法二:JSON.parse抑片、JSON.stringify
const newObj = JSON.parse(JSON.stringify(oldObj));
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市杨赤,隨后出現(xiàn)的幾起案子敞斋,更是在濱河造成了極大的恐慌,老刑警劉巖望拖,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件渺尘,死亡現(xiàn)場離奇詭異,居然都是意外死亡说敏,警方通過查閱死者的電腦和手機鸥跟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來盔沫,“玉大人医咨,你說我怎么就攤上這事〖艿” “怎么了拟淮?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長谴忧。 經(jīng)常有香客問我很泊,道長,這世上最難降的妖魔是什么沾谓? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任委造,我火速辦了婚禮,結(jié)果婚禮上均驶,老公的妹妹穿的比我還像新娘昏兆。我一直安慰自己,他們只是感情好妇穴,可當(dāng)我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布爬虱。 她就那樣靜靜地躺著,像睡著了一般腾它。 火紅的嫁衣襯著肌膚如雪跑筝。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天瞒滴,我揣著相機與錄音继蜡,去河邊找鬼。 笑死逛腿,一個胖子當(dāng)著我的面吹牛稀并,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播单默,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼碘举,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了搁廓?” 一聲冷哼從身側(cè)響起引颈,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎境蜕,沒想到半個月后蝙场,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡粱年,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年售滤,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片台诗。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡完箩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出拉队,到底是詐尸還是另有隱情弊知,我是刑警寧澤,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布粱快,位于F島的核電站秩彤,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏事哭。R本人自食惡果不足惜漫雷,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望慷蠕。 院中可真熱鬧珊拼,春花似錦、人聲如沸流炕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽每辟。三九已至剑辫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間渠欺,已是汗流浹背妹蔽。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人胳岂。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓编整,卻偏偏與公主長得像,于是被迫代替她去往敵國和親乳丰。 傳聞我的和親對象是個殘疾皇子掌测,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,440評論 2 348

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