除了遞歸,還可以使用迭代來實現深拷貝。具體來說,可以使用堆疊來保存需要處理的對象,然後在循環中不斷出堆疊並進行拷貝操作,直到堆疊為空為止。
以下是一個使用迭代實現深拷貝的示例代碼:
function deepClone(obj) {
let stack = [obj];
let copy = {};
while (stack.length) {
let cur = stack.pop();
for (let key in cur) {
if (cur.hasOwnProperty(key)) {
let value = cur[key];
if (typeof value === 'object') {
// 處理數組
if (Array.isArray(value)) {
copy[key] = [];
for (let i = 0; i < value.length; i++) {
copy[key][i] = value[i];
if (typeof value[i] === 'object') {
stack.push(value[i]);
}
}
}
// 處理對象
else {
copy[key] = {};
for (let k in value) {
copy[key][k] = value[k];
if (typeof value[k] === 'object') {
stack.push(value[k]);
}
}
}
} else {
copy[key] = value;
}
}
}
}
return copy;
}