黄舟2017-05-19 10:27:31
현재 obj가 객체인지 배열인지 확인하세요. 배열이면 결과도 배열이고, 그렇지 않으면 결과는 일반 객체입니다
당신의 이해가 잘못되었습니다. 이 문장은 obj가 존재하고 객체인 경우
如果 obj 存在,并且是对象
如果不是引用类型(对象),则说明当前键的值是基础类型,则直接将对应新的 result 对应的 key 也设置为这个值就可以了
by the way. 因为深拷贝一个对象有可能会造成内存泄漏问题。因为 key 有可能引用一个类型,从而在内部引用自身造成内存泄漏,所以深拷贝在遇到引用类型的 key 时会仅仅把 heap 内存的地址进行复制。
而且题目中第一行通过判断 splice
来判断是数组还是对象是不严谨的,万一对象下有个叫 splice 的属性刚好是函数呢,Array.isArray 方法的支持度很好,可以换成这个。
ES6的话直接 Object.assign()
splice
를 판단하여 배열인지 객체인지 판단하는 데 엄격하지 않습니다. 객체 아래에 우연히 함수가 된 splice라는 속성이 있으면 어떻게 되나요? Array.isArray 메소드 지원이 아주 좋습니다. 이 메소드로 대체할 수 있습니다. 🎜
🎜ES6의 경우 Object.ass()
를 사용하세요. 🎜漂亮男人2017-05-19 10:27:31
배열에만 splice 메서드가 있으므로 obj가 객체인지 배열인지 확인하세요. obj.splice
에 obj가 배열임을 나타내는 반환 값이 있으면 결과도 배열입니다. 그렇지 않으면 결과는 객체입니다. obj.splice
有返回值说明obj是数组,那么result也是数组,否则result就是对象。
if(obj存在,并且obj是对象),因为null的typeof
也是object,多一步判断可以去掉null。
如果是复制的值是一个private
值,那么就直接赋值就可以,如果是对象,那么就像上一步一样递归的复制对象,直到复制的值是private
typeof
도 객체이기 때문에 한 단계 더 판단하여 null을 제거할 수 있습니다.
private
값인 경우 값을 직접 할당하면 됩니다. 객체인 경우 복사된 값이 private이 될 때까지 이전 단계와 같이 객체를 재귀적으로 복사합니다.
값. 🎜🎜
🎜
🎜얕은 카피와 깊은 카피를 얘기하면 뻔뻔하게도 제가 쓴 글을 읽어보시길 권합니다...🎜/a/11...🎜