說到這個其實要引申出乙個知識點,那便是儲存型別,簡單來說分為值型別(又名 原始型別,六種 → string,number,null,undefined,boolean,symbol(不重複得值))和引用型別(又名 物件型別 例如 function,array)其中常見值型別有string、number、boolean、引用型別有function、array
引用型別有this指標指向問題、所以本次說的淺深拷貝也是指引用型別
let test =let demo =test
test.name = 'changes'
//其實 demo 並沒有變值 但確實 被test再次賦值給帶跑偏了
console.log(demo) //
changes
console.log(test) //
changes
let test = //let demo = object.assign({},test)
let demo =
test.name = 'changes'
console.log(demo) //zachary
console.log(test) //changes
let test = [1,2,3]let demo =object.assign(,test)
//let demo = [...test]
test.push('changes')
console.log(demo) //[1, 2, 3]
console.log(test) //[1, 2, 3, "changes"]
let map =}//let clonemap = 對於深拷貝無效
//let clonemap = object.assign({},map) 對於深拷貝無效
let clonemap =json.parse(json.stringify(map))
clonemap.province.jangxi='changes'
console.log(clonemap) //jangxi:changes
console.log(map)//jiangxi:'江西省'
會忽略 undefined不能序列化函式
不能解決迴圈引用的物件
但是在通常情況下,複雜資料都是可以序列化的,所以這個函式可以解決大部分問題,並且該函式是內建函式中處理深拷貝效能最快的
深拷貝和淺拷貝
淺拷貝就是物件的資料成員之間的簡單賦值,如你設計了乙個沒有類而沒有提供它的複製建構函式,當用該類的乙個物件去給令乙個物件賦值時所執行的過程就是淺拷貝,如 class a a private int data int main 這一句b a 就是淺拷貝,執行完這句後b.data 5 如果物件中沒有其他...
淺拷貝和深拷貝
以下情況都會呼叫拷貝建構函式 乙個物件以值傳遞的方式傳入函式體 例如 已知class a,class b void func a a void func a a func b b 此時函式對b的操作是呼叫拷貝建構函式後的臨時拷貝物件。多數傳指標 乙個物件以值傳遞的方式從函式返回 如 return b...
深拷貝和淺拷貝
ios提供了copy和mutablecopy方法,顧名思義,copy就是複製了乙個imutable的物件,而mutablecopy就是複製了乙個mutable的物件。以下將舉幾個例子來說明。1 系統的非容器類物件 這裡指的是nsstring nsnumber等等一類的物件。nsstring stri...