今天就跟大家聊聊有關在Java項目中如何實現實例化,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
Java實例化的幾種方法總結
Java創建有四種方式:
(1)用new 語句創建對象,這是最常用的創建對象方法。
(2)運用反射手段,調用Java.lang.Class或者java.lang.reflect.Constructor類的newInstance()實例方法。
(3)調用對象的clone()方法
(4)運用反序列化手段,調用java.io.ObjectInputStream對象的readObject()方法。
1.用new語句創建對象
User user = new User();
2.運用反射機制
根據依賴倒轉原則,實際編碼過程中要針對接口編程而不是具體類編程。在面向接口編程的模式中,經常用此方法來動態創建實例。如從XML配置文件中獲取具體子類的類名字符串subClassName,然后根據獲得的類名字符串進行實例化:
Class c = Class.forName(subClassName);
(1)java.lang.Class.newInstance()
User user = (User)c.newInstance();// 不帶參數
(2)java.lang.reflect.Constructor類的newInstance()
Constructor con = c.getConstructor(String.class); User user = (User) con.newInstance("name");
public Object getNewObject(String className) throws ClassNotFoundException, InstantiationException, IllegalAccessException { //class.forName(類的全路徑)、實例對象.class(屬性)、實例對象getClass(),這三種方式都能得到class Class tClass=Class.forName(className); Object tObject=tClass.newInstance(); return tObject; }
3.調用對象的clone()方法
clone指克隆
User user1 = new User(1,"dan"); User user2 = null; user2 = (User) user1.clone();
4.運用反序列化手段
序列化:將對象狀態轉化為可保持或傳輸的格式的過程,被序列化的對象必須implments Serializable
反序列化:將流轉化成對象的過程
當兩個進程在進行遠程通信時,彼此可以發送各種類型的數據。無論是何種類型的數據,都會以二進制序列的形式在網絡上傳送。發送方需要把這個Java對象轉換為字節序列,即java對象序列,才能在網絡上傳送,即序列化過程;接收方則需要把字節序列再恢復為java對象,即反序列化。
import java.io.ObjectOutputStream; import java.io.ObjectInputStream; import java.io.FileInputStream; import java.io.FileOutputStream; import java.util.Date; import java.lang.management.*; public class Test { //序列化對象到文件 public static void serialize(String fileName){ try { //創建一個對象輸出流,講對象輸出到文件 ObjectOutputStream out=new ObjectOutputStream(new FileOutputStream(fileName)); UserInfo user=new UserInfo("renyanwei","888888",20); out.writeObject(user); //序列化一個會員對象 out.close(); } catch (Exception x) { System.out.println(x.toString()); } } //從文件反序列化到對象 public static void deserialize(String fileName){ try { //創建一個對象輸入流,從文件讀取對象 ObjectInputStream in=new ObjectInputStream(new FileInputStream(fileName)); //讀取UserInfo對象并調用它的toString()方法 UserInfo user=(UserInfo)(in.readObject()); System.out.println(user.toString()); in.close(); } catch (Exception x) { System.out.println(x.toString()); } } public static void main(String[] args) { serialize("D:\\test.txt"); System.out.println("序列化完畢"); deserialize("D:\\test.txt"); System.out.println("反序列化完畢"); } }
(1)和(2)都會明確的顯式的調用構造函數 ;(3)是在內存上對已有對象的影印,所以不會調用構造函數 ;(4)是從文件中還原類的對象,也不會調用構造函數。
看完上述內容,你們對在Java項目中如何實現實例化有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。