導航:首頁 > 編程語言 > java相同對象非空欄位拷貝

java相同對象非空欄位拷貝

發布時間:2023-08-21 12:11:53

java如何深度一個object

java深復制的例子:
1、創建Employer類,實現Cloneable介面:
class Employer implements Cloneable{
private String username;

public String getUsername() {
return username;
}

public void setUsername(String username) {
this.username = username;
}

@Override
public Object clone() throws CloneNotSupportedException {
return super.clone();
}
}

2、創建Employee類,實現Cloneable介面,並改寫clone方法,實現深復制:
class Employee implements Cloneable{
private String username;
private Employer employer;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Employer getEmployer() {
return employer;
}
public void setEmployer(Employer employer) {
this.employer = employer;
}

@Override
public Object clone() throws CloneNotSupportedException {
//克隆Employee對象並手動的進一步克隆Employee對象中包含的Employer對象
Employee employee = (Employee)super.clone();
employee.setEmployer((Employer) employee.getEmployer().clone());
return employee;
}
}

3、這樣,在客戶端拷貝的兩個Employee對象的Employer就互不影響了:
public static void main(String[] args) throws CloneNotSupportedException {
Employer employer = new Employer();
employer.setUsername("arthinking");

Employee employee = new Employee();
employee.setUsername("Jason");
employee.setEmployer(employer);

//employee2由employee深復製得到
Employee employee2 = (Employee) employee.clone();
//這樣兩個employee各自保存了兩個employer
employee2.getEmployer().setUsername("Jason");
System.out.println(employee.getEmployer().getUsername());
System.out.println(employee2.getEmployer().getUsername());
}

㈡ 在java中,如何復制一個對象比如說string對象

可以使用clone來實制現,clone用於為引用類型的復制
1.使用clone方法的類必須先實現Cloneable介面,不然clone方法會直接返回CloneNotSupportedException不支持克隆的異常
2、實現Cloneable介面的類應該使用公共方法重寫 Object.clone(它是受保護的)。某個對象實現了此介面就克隆它是不可能的。即使 clone 方法是反射性調用的,也無法保證它將獲得成功。
3、在Java.lang.Object類中克隆方法是這么定義的:
protected Object clone()
throws CloneNotSupportedException
創建並返回此對象的一個副本。表明是一個受保護的方法,同一個包中可見。
按照慣例,返回的對象應該通過調用 super.clone 獲得。

詳見關於clone的API文檔

㈢ java中創建對象的的兩種方式具體解釋,一個是new一個是調用Class類的newinstance方法

用newInstance與用new是區別的
區別在於創建對象的方式不一樣
前者是使用類載入機制,那麼為什麼會有兩種創建對象方式?這個就要從可伸縮、可擴展,可重用等軟體思想上解釋了。
Java中工廠模式經常使用newInstance來創建對象,因此從為什麼要使用工廠模式上也可以找到具體答案。

Class classes = Class.forName(「A」);
factory = (AInterface)classes .newInstance();
其中AInterface是A的介面,
如果下面這樣寫,你可能會理解:
String className = 「A」;Class c = Class.forName(className);factory = (AInterface)c.newInstance();
進一步,如果下面寫,你可能會理解:
String className = readfromXMlConfig;//從xml 配置文件中獲得字元串Class c = Class.forName(className);factory = (AInterface)c.newInstance();
上面代碼就消滅了A類名稱,優點:無論A類怎麼變化,上述代碼不變,甚至可以更換A的兄弟類B , C , D….等,只要他們繼承Ainterface就可以。
從jvm的角度看,我們使用new的時候,這個要new的類可以沒有載入;
但是使用newInstance時候,就必須保證:1、這個類已經載入;2、這個類已經連接了。而完成上面兩個步驟的正是class的靜態方法forName()方法,這個靜態方法調用了啟動類載入器(就是載入javaAPI的那個載入器)。
有了上面jvm上的理解,那麼我們可以這樣說,newInstance實際上是把new這個方式分解為兩步,即,首先調用class的載入方法載入某個類,然後實例化。
這樣分步的好處是顯而易見的。我們可以在調用class的靜態載入方法forName時獲得更好的靈活性,提供給了我們降耦的手段。
[補充:]
newInstance: 弱類型。低效率。只能調用無參構造。
new: 強類型。相對高效。能調用任何public構造。
newInstance()是實現IOC、反射、面對介面編程 和 依賴倒置 等技術方法的必然選擇,new 只能實現具體類的實例化,不適合於介面編程。
裡面就是通過這個類的默認構造函數構建了一個對象,如果沒有默認構造函數就拋出InstantiationException, 如果沒有訪問默認構造函數的許可權就拋出IllegalAccessException

閱讀全文

與java相同對象非空欄位拷貝相關的資料

熱點內容
excel怎麼做文件頭 瀏覽:703
為什麼word找不到文件菜單 瀏覽:671
ios15安裝後找不到描述文件 瀏覽:440
學編程怎麼學最有效 瀏覽:873
通過wifi傳文件到ipad 瀏覽:197
js隨機顏色 瀏覽:611
文件快速復制到u盤的軟體 瀏覽:443
如何檢查無線網路驅動是否正常 瀏覽:468
百度網盤來自分享的文件在哪裡 瀏覽:127
如何發視頻到騰訊視頻文件夾里 瀏覽:510
微信打開cad外部文件找不到 瀏覽:882
平板可以打開各種文件後綴的軟體 瀏覽:531
蘋果微信文件怎麼全選 瀏覽:749
手機里之前打開過的文件在哪裡找 瀏覽:685
cad能看word文件嗎 瀏覽:719
12306火車票系統後台資料庫 瀏覽:570
js翻譯德語 瀏覽:33
從哪裡可以下載a股的數據 瀏覽:437
邏輯文件名和物理文件名關系 瀏覽:66
怎麼查一個網站的外鏈 瀏覽:675

友情鏈接