| 订阅 | 在线投稿
分享
 
 
 

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- 王朝网络 版权所有