Следующий код взят из документации Oracle по обобщению -
class Node<T> {
public T data;
public Node(T data) { this.data = data; }
public void setData(T data) {
System.out.println("Node.setData");
this.data = data;
}
}
class MyNode extends Node<Integer> {
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");
Integer x = mn.data; // Causes a ClassCastException to be thrown.
}
}
Мое понимание этого кода -
Q - метод setData
переопределен или перегружен?
мое понимание - поскольку MyNode
расширяется Node<Integer>
, значение параметра типа T
установлено на Integer
.
, поэтому у класса Node
есть метод setData(Integer data)
как T = Integer, а у класса MyNode
есть метод setData(Integer data)
.
переопределяет , так как подпись такая же.
Q- является ли метод setData Overrided даже после стирания? Мое понимание -
после того, как мы стерли <T>
, метод set становится в Node
становится, setData(Object data)
и установленный метод Mynode
будет - setData(Integer data)
, так как нет параметра типа, нечего удалять.
Но это перегрузка .
Q - мы хотели перегрузку или переопределение?
Мое понимание - по внешнему видуметоды, определенные до стирания, мы хотели переопределить .
Q - Так как добиться оверидинга после стирания?
Мое понимание - К Метод моста .например:
setData(Object data){
setData((Integer) Data);
}
Правильно ли мое понимание?
Кроме того, class MyNode extends Node<Integer>
, когда Integer
передается в <T>
?когда супер называется?