假设我有这种等级:
public abstract class AbstractEntity implements Cloneable {
...
public AbstractEntity clone() {
Cloner cloner = new Cloner();
AbstractEntity cloned = cloner.deepClone(this);
return cloned;
}
}
public class EntityA extends AbstractEntity {
...
}
这很好,我可以做到:
EntityA e1 = new EntityA();
EntityA e2 = (EntityA) e1.clone();
但我必须做一个手动的类型转换。 有没有办法使用java Generics让 clone()方法返回子类的实际类型?
谢谢!
答案 0 :(得分:6)
我能想到的最接近的是:
public abstract class AbstractEntity<T extends AbstractEntity<T>>
implements Cloneable {
@SuppressWarnings("unchecked")
public T clone() {
Cloner cloner = new Cloner();
T cloned = (T) cloner.deepClone(this);
return cloned;
}
}
public class EntityA extends AbstractEntity<EntityA> {
...
}
public class EntityB extends AbstractEntity<EntityB> {
...
}
这不完全安全:你可以写:
public class EvilClass extends AbstractEntity<EntityA> {
...
}
...但这对你来说是否重要取决于你的使用案例。
答案 1 :(得分:3)
我认为不需要仿制药。您可以在抽象类中声明clone()方法,并覆盖它以返回子类中的子类。
package inheritance;
public abstract class AbstractEntity {
public abstract AbstractEntity clone();
}
package inheritance;
public class ClassA extends AbstractEntity {
@Override
public ClassA clone() { return null; }
}
package inheritance;
public class Driver {
/**
* @param args
*/
public static void main(String[] args) {
ClassA a = new ClassA();
ClassA b = a.clone();
System.out.println("all done");
}
}
这不是你想做的吗?