使用泛型在抽象类中实现常用方法

时间:2013-02-07 17:11:17

标签: java generics

假设我有这种等级:

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()方法返回子类的实际类型?

谢谢!

2 个答案:

答案 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");
    }

}

这不是你想做的吗?