python深拷贝实现原理,js递归实现深拷贝
經(jīng)過(guò)小編之前關(guān)于JavaScript深拷貝實(shí)現(xiàn)方式的介紹,大家已經(jīng)知道深拷貝能夠?qū)崿F(xiàn)真正意義上的數(shù)組和對(duì)象的拷貝。其實(shí)使用內(nèi)置對(duì)象JSON雖然簡(jiǎn)答,但不能將對(duì)對(duì)象的方法深拷貝,因此使用遞歸的方式就是最實(shí)用的,本文介紹使用遞歸的方式實(shí)現(xiàn)深拷貝的原理及具體實(shí)現(xiàn)。
1、實(shí)現(xiàn)原理:
使用遞歸的方式實(shí)現(xiàn)數(shù)組、對(duì)象的深拷貝。
先判斷各個(gè)字段類(lèi)型,然后用遞歸解決嵌套數(shù)據(jù)。
判斷拷貝的要進(jìn)行深拷貝的是數(shù)組還是對(duì)象,是數(shù)組的話(huà)進(jìn)行數(shù)組拷貝,對(duì)象的話(huà)進(jìn)行對(duì)象拷貝。
進(jìn)行深拷貝的不能為空,并且是對(duì)象或者是數(shù)組。
2、具體實(shí)現(xiàn):function deepClone(obj){
let objClone = Array.isArray(obj) ? [] : {};
if (obj && typeof obj === 'object') {
for(let key in obj){
if (obj[key] && typeof obj[key] === 'object'){ //判斷對(duì)象的這條屬性是否為對(duì)象
objClone[key] = deepClone(obj[key]); //若是對(duì)象進(jìn)行嵌套調(diào)用
}else{
objClone[key] = obj[key]
}
}
}
return objClone; //返回深度克隆后的對(duì)象
}
以上就是使用遞歸的方式實(shí)現(xiàn)深拷貝的原理及具體實(shí)現(xiàn),希望能對(duì)你有所幫助。更多js學(xué)習(xí)推薦:js教程。
總結(jié)
以上是生活随笔為你收集整理的python深拷贝实现原理,js递归实现深拷贝的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: dm_php库,dmandwp系统 PH
- 下一篇: php flash chat,Flash