프로그래밍에서의 심층 복사와 얕은 복사
얕은 복사에는 원본과 동일한 기본 데이터를 참조하는 새 개체를 만드는 작업이 포함됩니다. 반면에 전체 복사는 원본과 관련된 모든 데이터의 독립적인 복제본을 포함하는 새 개체를 구성합니다.
다음 C 클래스를 고려하세요.
<code class="c++">class X { public: int i; int *pi; X() : pi(new int) {} X(const X& copy) : i(copy.i), pi(copy.pi) {} };</code>
이 경우 얕은 복사가 발생합니다. pi를 할당할 때 동일한 int 객체를 가리키는 원본 및 복사된 X 객체 모두에서:
<code class="c++">X original; X copy(original);</code>
반면, 전체 복사에는 새 int 객체가 할당되는 복사 생성자의 단계가 포함됩니다.
<code class="c++">class X { public: int i; int *pi; X() : pi(new int) {} X(const X& copy) : i(copy.i), pi(new int(*copy.pi)) {} };</code>
결과적으로 복사된 X 개체는 원본과 동일한 값을 가진 자체 int 개체를 갖게 됩니다.
처음에는 기본 복사 생성자가 항상 얕은 복사를 수행하는 것으로 생각되었습니다. 그러나 각 멤버의 유형에 따라 행동이 달라진다는 것이 밝혀졌습니다. 표준은 멤버별 복사를 지정합니다. 즉, 내장 할당 연산자를 사용하여 스칼라 유형(예: int)이 복사된다는 의미입니다.
따라서 깊은 복사와 얕은 복사 사이의 선택은 애플리케이션의 특정 요구 사항에 따라 달라집니다. 그리고 복사되는 데이터의 특성.
위 내용은 깊은 사본과 얕은 사본: 언제 어느 것을 선택해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!