1. 개념
새 개체는 원본 개체와 아무런 관련이 없습니다. 새 개체는 원본 개체와 동일하지 않습니다. 이전 개체와 동일. 구체적으로 다음과 같은 차이점을 확인할 수 있습니다.
(1) 속성이 기본 유형(int, double, long, boolean 등)인 경우 기본 유형의 값이 복사됩니다.
(2) 속성은 참조 유형이고 메모리는 주소를 복사하므로(즉, 참조를 복사하지만 참조된 개체는 복사하지 않음) 개체 중 하나가 주소를 변경하면 다른 개체에 영향을 미칩니다.
2. 원리
프로토타입 개체의 멤버 변수가 값 유형인 경우 복사본이 복제 개체에 복사됩니다. 즉, 프로토타입의 멤버 변수가 힙에 독립적인 공간을 갖는다는 의미입니다. object는 참조 유형이므로 참조 개체의 주소가 복제본 개체에 복사됩니다. 이는 프로토타입 개체와 복제본 개체의 멤버 변수가 동일한 메모리 주소를 가리킨다는 의미입니다. 즉, 얕은 복제에서는 개체를 복사할 때 개체 자체와 개체에 포함된 값 형식의 멤버 변수만 복사되고 참조 형식의 멤버 개체는 복사되지 않습니다.
3. 인스턴스를 사용하여
복사해야 하는 클래스에 Cloneable 인터페이스를 구현하고 해당 clone()method
class Father{ String name; public Father(String name) { this.name=name; } @Override public String toString() { return "Father{" + "name='" + name + '\'' + '}'; } } class Son implements Cloneable { int age; String name; Father father; public Son(String name,int age) { this.age=age; this.name = name; } public Son(String name,int age, Father father) { this.age=age; this.name = name; this.father = father; } @Override public String toString() { return "Son{" + "age=" + age + ", name='" + name + '\'' + ", father=" + father + '}'; } @Override protected Son clone() throws CloneNotSupportedException { return (Son) super.clone(); } } public class test { public static void main(String[] args) throws CloneNotSupportedException { Father f=new Father("bigFather"); Son s1 = new Son("son1",13); s1.father=f; Son s2 = s1.clone(); System.out.println(s1); System.out.println(s2); System.out.println("s1==s2:"+(s1 == s2));//不相等 System.out.println("s1.name==s2.name:"+(s1.name == s2.name));//相等 System.out.println(); //但是他们的Father father 和String name的引用一样 s1.age=12; s1.father.name="smallFather";//s1.father引用未变 s1.name="son222";//类似 s1.name=new String("son222") 引用发生变化 System.out.println("s1.Father==s2.Father:"+(s1.father == s2.father));//相等 System.out.println("s1.name==s2.name:"+(s1.name == s2.name));//不相等 System.out.println(s1); System.out.println(s2); } }를 재정의합니다.
위 내용은 Java 얕은 복사본을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!