我是java的新手.我仍然觉得我必须了解很多,所以如果这个问题看起来很愚蠢,请原谅我.现在我正在浏览http://docs.oracle.com/javase/tutorial/java/generics/bridgeMethods.html
在这里,我发现了很多困惑.
public class Node{ public T data; public Node(T data) { this.data = data; } public void setData(T data) { System.out.println("Node.setData"); this.data = data; } } public class MyNode extends Node { public MyNode(Integer data) { super(data); } public void setData(Integer data) { System.out.println("MyNode.setData"); super.setData(data); } public static void main(String[] args) { MyNode mn = new MyNode(5); Node n = mn; // A raw type - compiler throws an unchecked warning n.setData("Hello"); // Causes a ClassCastException to be thrown. Integer x = mn.data; } }
当我运行此代码时,我得到以下错误
Exception in thread "main" java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Integer at MyNode.setData(MyNode.java:1) at MyNode.main(MyNode.java:14)
下面是混淆
1)为什么它显示行号1
2)如果您通过博客阅读他们说类型擦除将替换类型参数将替换上面的代码如下
public class Node { private Object data; public Node(Object data) { this.data = data; } public void setData(Object data) { System.out.println("Node.setData"); this.data = data; } } public class MyNode extends Node { public MyNode(Integer data) { super(data); } public void setData(Integer data) { System.out.println(data); super.setData(data); } public static void main(String[] args) { MyNode mn = new MyNode(5); Node n = mn; // A raw type - compiler throws an unchecked warning n.setData("Hello"); // Causes a ClassCastException to be thrown. //Integer x = mn.data } }
当我运行上面的代码我没有错误,代码运行正常
从文档两者相同?为什么这种行为不同
现在关于oop的另一个最重要的问题是当我们扩展一个类时,当我们调用超级构造函数时,虽然没有创建超级对象,那么调用super的用途是什么.请解释.