Java Generics – 原始类型和参数化类型转换
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Java Generics – 原始类型和参数化类型转换,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2866字,纯文字阅读大概需要5分钟。
内容图文
![Java Generics – 原始类型和参数化类型转换](/upload/InfoBanner/zyjiaocheng/789/7a898ddd9b514ae6abf6316a8bff93fa.jpg)
我一直在阅读Java Generics Tutorials和Stackoverflow中很少涉及泛型的线程,但仍无法理解具体案例.
这里是:
public class Box<T>
{
private T t;
public T getT ()
{
return t;
}
public void setT (T t)
{
this.t = t;
}
public static void main (String[] args)
{
Box<Integer> intBox = new Box<Integer>();
Box rawBox = intBox;
rawBox.setT("NBA");
System.out.println(rawBox.getT());
System.out.println(intBox.getT());
/*1*/ //System.out.println(intBox.getT().toString());
}
}
这是交易,我理解的第一个印刷品,即
System.out.println(rawBox.getT());
打印NBA,因为rawBox是原始类型的Box T,它“给”我们对象.
我没有得到的是第二次印刷:
System.out.println(intBox.getT());
打印NBA.
intBox是泛型类型(在本例中为Box of Integers),这意味着它的getter方法应该返回一个类型为T的值(在本例中为Integer),所以我理解的是那里保存的String对象应该被转换to Integer(因为这是给Box T的参数类型),并且应该在运行时引发ClassCastException,但它不会发生,为什么会这样?
顺便说一下,注释号/ 1 /会增加混乱,因为如果我要取消注释它,它会导致在ruuntime中引发ClassCastException(String不能转换为Integer),我不明白
谢谢大家:)
解决方法:
有时很难猜出Java会插入已检查的强制转换.通常,它只会在必要时插入它们.理解您看到的行为的最佳方法是检查字节码!
如果我们运行javap -c Box.class(在使用/ * 1 * / uncommented编译之后),我们会看到:
public static void main(java.lang.String[]);
Code:
...
20: invokevirtual #8 // Method getT:()Ljava/lang/Object;
23: invokevirtual #9 // Method java/io/PrintStream.println:(Ljava/lang/Object;)V
26: getstatic #7 // Field java/lang/System.out:Ljava/io/PrintStream;
29: aload_1
30: invokevirtual #8 // Method getT:()Ljava/lang/Object;
33: invokevirtual #9 // Method java/io/PrintStream.println:(Ljava/lang/Object;)V
36: getstatic #7 // Field java/lang/System.out:Ljava/io/PrintStream;
39: aload_1
40: invokevirtual #8 // Method getT:()Ljava/lang/Object;
43: checkcast #10 // class java/lang/Integer
46: invokevirtual #11 // Method java/lang/Integer.toString:()Ljava/lang/String;
49: invokevirtual #12 // Method java/io/PrintStream.println:(Ljava/lang/String;)V
52: return
你可以在这里看到,JVM实际需要转换为整数的唯一时间是#43(checkcast).这样它就可以调用虚拟的Integer.toString().
对println(#33)的调用不需要强制转换,因为println需要一个Object而不是一个Integer(也许你认为你正在调用println(int),但你不是).所以JVM永远不需要检查它是否为整数,因为它不需要.
如果不是调用println(Object),而是调用了接受Integer的方法,则应该看到ClassCastException.
例如,这个:
...
print(intBox.getT());
}
private static void print(Integer integer) {
System.out.println(integer);
}
将执行演员:
26: aload_1
27: invokevirtual #8 // Method getT:()Ljava/lang/Object;
30: checkcast #10 // class java/lang/Integer
33: invokestatic #11 // Method print:(Ljava/lang/Integer;)V
内容总结
以上是互联网集市为您收集整理的Java Generics – 原始类型和参数化类型转换全部内容,希望文章能够帮你解决Java Generics – 原始类型和参数化类型转换所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。