自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JavaScript中淺拷貝和深拷貝的區(qū)別和實(shí)現(xiàn)

開發(fā) 前端
要理解 JavaScript中淺拷貝和深拷貝的區(qū)別,首先要明白JavaScript的數(shù)據(jù)類型。JavaScript有兩種數(shù)據(jù)類型,基礎(chǔ)數(shù)據(jù)類型和引用數(shù)據(jù)類型。

前言

要理解 JavaScript中淺拷貝和深拷貝的區(qū)別,首先要明白JavaScript的數(shù)據(jù)類型。JavaScript有兩種數(shù)據(jù)類型,基礎(chǔ)數(shù)據(jù)類型和引用數(shù)據(jù)類型。

1. 基礎(chǔ)數(shù)據(jù)類型: undefined、boolean、number、string、null,保存在棧內(nèi)存中的簡(jiǎn)單數(shù)據(jù)

2. 引用數(shù)據(jù)類型:Array、對(duì)象、Function,保存在堆內(nèi)存空間中

概述

如下圖:

 

JavaScript中淺拷貝和深拷貝的區(qū)別和實(shí)現(xiàn)

 

注釋:

a1 = 0;a2 = 'this is str';a3 = null, 存放在棧內(nèi)存中;

var c =[1,2,3] 與 var d = {m:20} ,**變量名與內(nèi)存地址存儲(chǔ)在棧內(nèi)存中**,**但是**[1,2,3]與{m:20} 作為**對(duì)象存儲(chǔ)在堆內(nèi)存中**;

基礎(chǔ)數(shù)據(jù)類型的復(fù)制

var a = 20;

var b = a;

如下圖:

 

JavaScript中淺拷貝和深拷貝的區(qū)別和實(shí)現(xiàn)

 

引用數(shù)據(jù)類型的復(fù)制

var m ={ a:10, b:20};

var n = m;

 

JavaScript中淺拷貝和深拷貝的區(qū)別和實(shí)現(xiàn)

 

m與n指向同一個(gè)內(nèi)存空間,當(dāng)m或者n改變時(shí),另一個(gè)也跟著改變

m.a = 'web秀';

console.log(n.a);

// 輸出 web秀

怎么樣使引用數(shù)據(jù)類型有各自獨(dú)立的內(nèi)存空間???

深度拷貝方法

采用遞歸的方法拷貝對(duì)象

 

JavaScript中淺拷貝和深拷貝的區(qū)別和實(shí)現(xiàn)

 

## 奇技淫巧

利用**基礎(chǔ)數(shù)據(jù)類型**方式,把對(duì)象轉(zhuǎn)換成字符串,進(jìn)行復(fù)制。具體點(diǎn)說就是,用JSON.stringify與JSON.parse實(shí)現(xiàn)深拷貝。原因是JSON.stringify(obj)轉(zhuǎn)換成字符串,變成基本數(shù)據(jù)類型,基本類型拷貝是直接在棧內(nèi)存新開空間,直接復(fù)制一份名-值,不影響之前的對(duì)象。請(qǐng)看代碼:

 

JavaScript中淺拷貝和深拷貝的區(qū)別和實(shí)現(xiàn)

 

總結(jié)

1. 淺拷貝(shallow copy):只復(fù)制指向某個(gè)對(duì)象的指針,而不復(fù)制對(duì)象本身,新舊對(duì)象共享一塊內(nèi)存;

2. 深拷貝(deep copy):復(fù)制并創(chuàng)建一個(gè)一摸一樣的對(duì)象,不共享內(nèi)存,修改新對(duì)象,舊對(duì)象保持不變;

實(shí)現(xiàn)深拷貝主要有2種方法

(1)遞歸

(2)JSON.stringify結(jié)合JSON.parse

責(zé)任編輯:龐桂玉 來源: 今日頭條
相關(guān)推薦

2021-07-16 12:33:24

Javascript深拷貝淺拷貝

2018-05-10 14:20:18

前端JavaScript深拷貝

2020-10-12 08:35:22

JavaScript

2017-08-16 13:30:05

Java深拷貝淺拷貝

2021-09-27 11:07:11

深拷貝淺拷貝內(nèi)存

2022-07-26 08:07:03

Python淺拷貝深拷貝

2024-04-17 09:01:08

Python深拷貝淺拷貝

2023-09-22 12:21:33

Python深拷貝淺拷貝

2020-08-03 08:24:26

原型模式拷貝

2009-05-19 17:28:44

深拷貝淺拷貝clone()

2023-05-17 08:42:46

深拷貝Golang

2025-04-27 09:45:58

JavaScript深拷貝淺拷貝

2020-06-23 08:41:47

JavaScript開發(fā)技術(shù)

2022-09-30 15:03:09

C語言深拷貝淺拷貝

2023-05-17 07:36:00

淺拷貝深拷貝對(duì)象

2017-05-24 11:54:55

Javascript深拷貝

2021-01-08 06:15:09

深拷貝淺拷貝寫時(shí)拷貝

2022-11-07 11:37:27

深拷貝淺拷貝底層

2024-02-05 22:56:16

C++拷貝開發(fā)

2024-03-15 15:03:23

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)