banner
SlhwSR

SlhwSR

热爱技术的一名全栈开发者
github
bilibili

除了递归有什麼其他方式實現深拷貝

除了遞歸,還可以使用迭代來實現深拷貝。具體來說,可以使用堆疊來保存需要處理的對象,然後在循環中不斷出堆疊並進行拷貝操作,直到堆疊為空為止。

以下是一個使用迭代實現深拷貝的示例代碼:


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;
}

載入中......
此文章數據所有權由區塊鏈加密技術和智能合約保障僅歸創作者所有。