한 개체의 참조를 다른 개체에 복사하는 방법에는 세 가지가 있습니다. 첫 번째 방법은 직접 할당, 두 번째 방법은 얕은 복사, 세 번째 방법은 깊은 복사입니다.
1. 직접 할당
Java에서 A a1 = a2 이는 실제로 참조를 복사합니다. 이는 a1과 a2가 동일한 객체를 가리킨다는 의미입니다. 따라서 a1이 변경되면 a2의 멤버 변수도 변경됩니다.
2. 얕은 복사본(참조는 복사하지만 참조된 개체는 복사하지 않음)
얕은 복사본이라고도 합니다. 새 객체를 생성한 다음 현재 객체의 비정적 필드를 새 객체에 복사합니다. 필드가 값 유형이면 필드를 복사하고 참조 유형은 복사하지 않습니다. 물체. 따라서 원본 개체와 해당 복사본은 동일한 개체를 참조합니다.
(추천 영상: java 영상 튜토리얼)
class Resume implements Cloneable{ public Object clone() { try { return (Resume)super.clone(); } catch (Exception e) { e.printStackTrace(); return null; } } }
3. Deep Copy(객체와 해당 참조 객체 복사)
Deep Copy라고도 함. 객체 자체를 복사할 뿐만 아니라 객체 전체를 복사함 객체 객체가 가리키는 참조입니다.
class Student implements Cloneable { String name; int age; Professor p; Student(String name, int age, Professor p) { this.name = name; this.age = age; this.p = p; } public Object clone() { Student o = null; try { o = (Student) super.clone(); } catch (CloneNotSupportedException e) { System.out.println(e.toString()); } o.p = (Professor) p.clone(); return o; } }
clone() 메소드를 사용하여 객체를 복제하는 단계:
1) 복제된 클래스는 Cloneable 인터페이스를 구현해야 합니다.
2) 복제된 클래스는 clone() 메서드를 재정의해야 합니다.
그렇다면 프로그래밍할 때 사용할 복사 방법을 선택하는 방법은 무엇입니까? 먼저 클래스에서 기본 유형(즉, 객체)이 아닌 데이터 멤버가 있는지 확인합니다. 그렇지 않다면, 그냥 super.clone()을 반환하세요. 그렇다면 클래스에 포함된 기본 유형이 아닌 모든 멤버 변수가 깊은 복사를 구현하는지 확인하세요.
확장: 얕은 복사와 깊은 복사의 차이점은 무엇인가요?
Shallow Clone: 복사된 객체의 모든 변수는 원본 객체와 동일한 값을 포함하며, 다른 모든 객체의 참조는 여전히 원본 객체를 가리킵니다. 즉, 얕은 복사본은 해당 개체가 참조하는 개체가 아닌 해당 개체만 복사합니다.
Deep Clone: 복사된 개체의 모든 변수에는 다른 개체를 참조하는 변수를 제외하고 원본 개체와 동일한 값이 포함됩니다. 다른 개체를 참조하는 변수는 원래 참조된 개체가 아니라 복사되는 새 개체를 가리킵니다. 즉, Deep Copy는 복사된 개체가 참조하는 모든 개체를 복사합니다.
확장:
프로토타입 모드는 주로 객체 복사에 사용됩니다. 인터페이스를 구현하고(Cloneable 인터페이스 구현) 메소드를 다시 작성하여(Object 클래스의 clone() 메소드를 다시 작성) 프로토타입 모드를 완성합니다. .
프로토타입 모드의 복사는 "얕은 복사"와 "깊은 복사"로 나누어집니다.
얕은 복사: 값 유형의 멤버 변수 값을 복사하고, 참조의 멤버 변수의 참조만 복사합니다. 유형이지만 참조 객체는 아닙니다.
복사: 값형 멤버변수의 값을 복사하고, 참조형 멤버변수의 참조객체를 복사합니다.
(Object 클래스의 clone 메소드는 객체의 기본 데이터 유형 값만 복사합니다. 배열, 컨테이너 객체, 참조 객체 등은 복사되지 않습니다. 이는 얕은 복사본입니다. 구현하려는 경우 깊은 복사를 하려면 반드시 프로토타입 모드에 넣어야 합니다. 배열, 컨테이너 객체, 참조 객체 등은 별도로 복사됩니다.)
프로토타입 모드의 장점:
1. 프로토타입 모드를 사용하여 객체 생성 프로세스를 단순화할 수 있습니다.
2. 항상 객체를 생성하는 모드인데, 객체를 직접 새로 만드는 것보다 성능이 훨씬 좋습니다. 왜냐하면 Object 클래스의 clone 메소드는 메모리에서 바이너리 스트림을 직접 작동하는 로컬 메소드이기 때문입니다. 큰 개체를 복사할 때 성능 차이는 매우 분명합니다.
프로토타입 패턴의 사용 시나리오:
위의 장점 때문에 유사한 객체를 반복적으로 생성해야 할 때 프로토타입 패턴 사용을 고려할 수 있습니다. 예를 들어, 루프 내에서 객체를 생성해야 하는 경우, 객체 생성 프로세스가 복잡하거나 루프가 많은 경우 프로토타입 패턴을 사용하면 생성 프로세스를 단순화할 수 있을 뿐만 아니라 시스템의 전반적인 성능을 크게 향상시킬 수 있습니다.
이 기사는 PHP 중국어 웹사이트, java tutorial 칼럼에서 가져온 것입니다. 환영합니다!
위 내용은 Java의 '얕은 복사본'과 '깊은 복사본'의 차이점과 구현(코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!