一直用等號賦值,今天發現一些莫名其妙的錯誤,看了好多文章才發現,原來對象賦值不能用等號,等於只能用於主類型的賦值(String,int,float之類),而如果是其他的類生產的對象,用等號是映射,並非賦值,只要改了等號一邊的值,另一邊的也跟著變化,就是說JAVA沒有開闢新的記憶體,只是給原來的對象再起了個名字而已。
如果需要賦值,就需要類實現Cloneable介面,實現clone()方法。
| 代碼如下 |
複製代碼 |
class D implements Cloneable{//實現Cloneable介面 String sex; D(String sex){ this.sex=sex; } @Override protected Object clone() throws CloneNotSupportedException { // 實現clone方法 return super.clone(); } }
|
賦值的時候:
| 代碼如下 |
複製代碼 |
D d=new D("男"); D d2=(D) d.clone();//把d賦值給d2 |
如果類中的變數不是主類型,而是對象,也需要調用該對象的clone()方法
下面是一個完整的例子:
| 代碼如下 |
複製代碼 |
public class Test2 { public static void main(String[] args) throws CloneNotSupportedException { // TODO Auto-generated method stub D d=new D("男"); C c=new C("張三","20",d); C new_c=(C) c.clone();//調用clone方法來賦值 new_c.name="李四"; d.sex="女";//d System.out.println(c.d.sex); System.out.println(c.name); } } class C implements Cloneable{ String name; String age; D d; C(String name,String age,D d) throws CloneNotSupportedException{ this.name=name; this.age=age; this.d=(D) d.clone();//調用clone方法來賦值,這樣即便外部的d發生變化,c裡的也不會變 } @Override protected Object clone() throws CloneNotSupportedException { // TODO Auto-generated method stub return super.clone(); } } class D implements Cloneable{//實現Cloneable介面 String sex; D(String sex){ this.sex=sex; } @Override protected Object clone() throws CloneNotSupportedException { // 實現clone方法 return super.clone(); } } |