1. java的實例化
對象是類的一個實例,創建對象的過程也叫類的實例化。對象是以類為模板來創建的。
在Java中,使用new關鍵字來創建對象,一般有以下三個步驟:
聲明:聲明一個對象,包括對象名稱和對象類型
實例化:使用關鍵字new來創建一個對象。
初始化:使用new創建對象時,會調用構造方法初始化對象。
2. Java實例化的幾種方式
1、用new語句創建對象,這是最常見的創建對象的方法。
2、通過工廠方法返回對象,如:String str = String.valueOf(23);
3、運用反射手段,調用java.lang.Class或者java.lang.reflect.Constructor類的newInstance()實例方法。如:Object obj = Class.forName("java.lang.Object").newInstance();
4、調用對象的clone()方法。
5、通過I/O流(包括反序列化),如運用反序列化手段,調用java.io.ObjectInputStream對象的 readObject()方法。
3. Java中什麼叫實例化
把一個類,變成實際存在的一個"例子",叫實例化.
說白了,如:
"人"是一個概念,相當於一個"類"
"小明"是一個具體存在的"人"的例子,相當於一個"實例".
把"人"變成"小明"的過程,就是"人的實例化".
4. java涓瀹炰緥鍖栨槸浠涔堟剰鎬
瀹炰緥鍖栨槸鎸囧湪緙栫▼涓鍒涘緩涓涓瀵硅薄鐨勮繃紼嬨傚湪Java璇璦涓錛屾垜浠浣跨敤鍏抽敭瀛椻渘ew鈥濇潵瀹炰緥鍖栦竴涓瀵硅薄銆傝繖涓榪囩▼鍖呮嫭涓哄硅薄鍒嗛厤鍐呭瓨絀洪棿銆佽皟鐢ㄥ硅薄鐨勬瀯閫犳柟娉曡繘琛屽垵濮嬪寲絳変竴緋誨垪鎿嶄綔銆傞氳繃瀹炰緥鍖栧彲浠ュ湪紼嬪簭涓浣跨敤瀵硅薄鐨勫睘鎬у拰鏂規硶錛屼互瀹屾垚鍚勭嶅姛鑳姐
瀹炰緥鍖栬繃紼嬩竴鑸鍒嗕負浠ヤ笅鍥涙ワ細絎涓姝ユ槸澹版槑瀵硅薄綾誨瀷錛屽嵆鍛婅瘔紼嬪簭鎴戜滑闇瑕佸壋寤虹殑瀵硅薄綾誨瀷鏄浠涔堬紱絎浜屾ユ槸浣跨敤鍏抽敭瀛椻渘ew鈥濆壋寤哄硅薄錛涚涓夋ユ槸璋冪敤瀵硅薄鐨勬瀯閫犳柟娉曡繘琛屽垵濮嬪寲錛涙渶鍚庝竴姝ユ槸灝嗗硅薄鐨勫紩鐢ㄤ繚瀛樺埌鍙橀噺涓錛屼互渚垮湪紼嬪簭涓浣跨敤銆
鍦↗ava涓錛屾瘡涓綾婚兘鍙浠ヨ瀹炰緥鍖栵紝涔熷彲浠ュ疄渚嬪寲澶氫釜瀵硅薄銆傝繖浜涘硅薄鐨勫睘鎬у拰鏂規硶鍦ㄤ笉鍚岀殑瀹炰緥涓鏄鐙絝嬬殑錛屽畠浠涔嬮棿涓嶄細鐩鎬簰褰卞搷銆傚疄渚嬪寲鍙浠ヨ╂垜浠鍦ㄤ竴涓綾葷殑鍩虹涓婂壋寤哄嚭澶氫釜鍏鋒湁涓嶅悓灞炴у拰鏂規硶鐨勫硅薄錛岃繖鏍峰氨鍙浠ュ湪涓嶅悓鐨勫満鏅涓浣跨敤涓嶅悓鐨勫疄渚嬨
5. java實例化
後兩種方法是靜態工廠方法。它們和new語句的區別如下:
我們要得到一個對象,馬上想到構造方法(new語句調用構造方法),其實,靜態工廠方法也可以替我們做到。
例如,在jdk1.4裡面,Boolean用了一個靜態方法來得到一個boolean對象:
public static Boolean valueOf(boolean b)
question:這個方法實際上並不返回一個object?
對的, sun的jdk 幫助裡面講: If a new Boolean instance is not required, this method should generally be used in preference to the constrUCtor Boolean(boolean).
但是,不是說靜態工廠方法所有時候都不返回一個object,只是不是所有時候都返回一個object。
使用靜態工廠方法和構造方法比較的優缺點:
優點:
1. 靜態工廠方法都是有自己的名字,輕易理解.
2. 靜態工廠方法並不要求每次都生成一個對象.比如上面提到的Boolean的public static Boolean valueOf(boolean b)就不會返回一個object. sun的jdk幫助文檔裡面也提到,在不需要得到一個對象的情況下,使用valueof方法可以得到性能的提升.
而且這樣,可以控制類在生的期間該類的句柄數,這個作用在單態(item 21)和類型安全(item 21)都是有用的.
3. 靜態工廠方法可以返回該類的任何子類,這給了程序員更大的選擇空間.
比如Collections,用了很多靜態工廠方法來得到immuable的set,map之類的.
而且靜態工廠方法可以強迫user通過介面來引用被返回的對象,而不是每次都使用構造函數,這是一個好習慣.
靜態工廠方法返回的類,在編寫含有靜態工廠方法這個類的時候,可以並不存在,這就提供了一種靈活的service provider framework.比如Java的密碼系統擴展(JCE),provider為user提供多個api實現,framework提供一種機制來register這些實現,用戶只需直接使用api,而不用考慮自己在使用哪個實現。
下面是這種機制的程序框架:
import java.util.*;
// Provider framework sketch
public abstract class Foo {
// Maps String key to corresponding Class object
private static Map implementations = null;
// Initializes implementations map the first time it´s called
private static synchronized void initMapIfNecessary() {
if (implementations == null) {
implementations = new HashMap();
// Load implementation class names and keys from
// Properties file, translate names into Class
// objects using Class.forName and store mappings.
// ...
}
}
public static Foo getInstance(String key) {
initMapIfNecessary();
Class c = (Class) implementations.get(key);
if (c == null)
return new DefaultFoo();
try {
return (Foo) c.newInstance();
} catch (Exception e) {
return new DefaultFoo();
}
}
public static void main(String[] args) {
System.out.println(getInstance("NonexistentFoo"));
}
}
class DefaultFoo extends Foo {
}
靜態工廠方法的缺點:
1. 僅僅有靜態工廠方法而沒有public的構造方法的類不能被繼續…這也不是沒有好處--可能能迫使程序員使用復合來代替繼續.
2. 有時候可能會導致與其他的static方法混淆.這個缺點可以通過使用標準的命名方法來區別於其他的static方法.
現在有兩種方法已經開始形成標准:
valueof(type k)-返回和k有相同值的句柄.
Getinstance-返回一個復合參數所描述的句柄.但是不一定和參數具有相同的值..這個方法在Provider framework裡面是很有用的.
所以,我們不要每次都毫不猶豫的使用構造方法,有時候靜態工廠方法可能是更加合適的.但是當你無法取捨的時候,還是使用構造方法吧,因為它是比較普通和標準的.
文章來源: 動態網站製作(www.knowsky.com) 出處:http://www.knowsky.com/369377.html