| 導購 | 订阅 | 在线投稿
分享
 
 
 

Java傳遞對象給期望原始類型參數的方法

來源:互聯網網民  2008-05-31 12:10:37  評論

術語 autoboxing 是指創建一個代表一個原始類型數據的對象;術語 unboxing 是指創建一個代表一個對象的值的原始類型數據。Java 1.5 中新的 autoboxing/unboxing 特性答應我們傳遞原始類型參數給那些期望包裝對象的方法,同樣地,也答應我們傳遞對象給那些期望原始類型參數的方法。

例如,假設我們有一個方法 foo(Interger val)。在 Java 1.5 之前,爲了傳遞一個一個原始類型值給這個方法,需要通過以下方式來做到:

int primitiveVal = 8;

foo(Integer.valueOf(8));

現在在 Java 1.5 中,可以使用原始類型數據直接調用 foo,而無須創建包裝類 Integer 的實例,如下:

foo(primitiveVal);

反之假如我們有一個期望原始類型參數的方法 bar(int val),一樣有一種簡單的方法處理。

下面是老的方法:

Integer wrapper = new Integer(8);

bar(wrapper.intValue());

而這裏是新方法:

bar(wrapper);

編譯器已經爲我們做了輔助工作。假如分析由編譯器爲下面這個類創建的代碼,你會發現編譯器使用了在老版本中完全一樣的調用方式。這裏有對 BoxingTip 類運行 javap -c 的輸出結果的摘要:

public static void main(java.lang.String[]);

...

10:bipush9

12:istore_2

13:iload_2

14:invokestatic#4; //Method

java/lang/Integer.valueOf:(I)Ljava/lang/Integer;

17:invokestatic#5; //Method foo:(Ljava/lang/Integer;)V

20:aload_1

21:invokevirtual #6; //Method java/lang/Integer.intValue:()I

24:invokestatic#7; //Method bar:(I)V

27:return

...

在第14行,編譯器調用了 Integer 的靜態方法valueOf() 爲 foo() 方法提供需要的值。在第21行,調用了現有 Integer 實例的 intValue() 方法提取 int 值傳遞給 bar() 方法。我們可以使用編譯器提供的 autoboxing/unboxing 特性,而無須理解背後究竟發生了什麽,但是知道編譯器爲你做了什麽始終都不是一件壞事。

在 Java 1.5 中這個新特性不僅僅是提供了句法方便。它是進化,而不是革命,但是它是新時期的到來,它將會使編寫 Java 代碼更加輕易。

public class BoxingTip {

public static void main(String []args) {

Integer wrapper = new Integer(8);

int primitiveValue = 9;

foo(primitiveValue);

bar(wrapper);

}

static void foo(Integer val) {

System.out.println( val);

}

static void bar(int val) {

System.out.print(val);

}

}

注重:這個提示中的代碼在 windows 2000 下使用 Java build 1.5.0-beta-b32c 編譯通過。假如要編譯這段代碼,必須使用 javac "-source 1.5" 選項。

 
特别声明:以上内容(如有图片或视频亦包括在内)为网络用户发布,本站仅提供信息存储服务。
 
  術語 autoboxing 是指創建一個代表一個原始類型數據的對象;術語 unboxing 是指創建一個代表一個對象的值的原始類型數據。Java 1.5 中新的 autoboxing/unboxing 特性答應我們傳遞原始類型參數給那些期望包裝對象的方法,同樣地,也答應我們傳遞對象給那些期望原始類型參數的方法。      例如,假設我們有一個方法 foo(Interger val)。在 Java 1.5 之前,爲了傳遞一個一個原始類型值給這個方法,需要通過以下方式來做到:      int primitiveVal = 8;   foo(Integer.valueOf(8));      現在在 Java 1.5 中,可以使用原始類型數據直接調用 foo,而無須創建包裝類 Integer 的實例,如下:      foo(primitiveVal);      反之假如我們有一個期望原始類型參數的方法 bar(int val),一樣有一種簡單的方法處理。      下面是老的方法:      Integer wrapper = new Integer(8);   bar(wrapper.intValue());      而這裏是新方法:      bar(wrapper);      編譯器已經爲我們做了輔助工作。假如分析由編譯器爲下面這個類創建的代碼,你會發現編譯器使用了在老版本中完全一樣的調用方式。這裏有對 BoxingTip 類運行 javap -c 的輸出結果的摘要:      public static void main(java.lang.String[]);   ...   10: bipush 9   12: istore_2   13: iload_2   14: invokestatic  #4; //Method    java/lang/Integer.valueOf:(I)Ljava/lang/Integer;   17: invokestatic  #5; //Method foo:(Ljava/lang/Integer;)V   20: aload_1   21: invokevirtual  #6; //Method java/lang/Integer.intValue:()I   24: invokestatic  #7; //Method bar:(I)V   27: return   ...      在第14行,編譯器調用了 Integer 的靜態方法valueOf() 爲 foo() 方法提供需要的值。在第21行,調用了現有 Integer 實例的 intValue() 方法提取 int 值傳遞給 bar() 方法。我們可以使用編譯器提供的 autoboxing/unboxing 特性,而無須理解背後究竟發生了什麽,但是知道編譯器爲你做了什麽始終都不是一件壞事。      在 Java 1.5 中這個新特性不僅僅是提供了句法方便。它是進化,而不是革命,但是它是新時期的到來,它將會使編寫 Java 代碼更加輕易。      public class BoxingTip {     public static void main(String []args) {       Integer wrapper = new Integer(8);       int primitiveValue = 9;              foo(primitiveValue);              bar(wrapper);     }        static void foo(Integer val) {       System.out.println( val);     }          static void bar(int val) {       System.out.print(val);     }    }      注重:這個提示中的代碼在 windows 2000 下使用 Java build 1.5.0-beta-b32c 編譯通過。假如要編譯這段代碼,必須使用 javac "-source 1.5" 選項。
󰈣󰈤
王朝萬家燈火計劃
期待原創作者加盟
 
 
 
>>返回首頁<<
 
 
 
 
 
 熱帖排行
 
 
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有