6

假设我有这个层次结构:

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

谢谢!

4

2 回答 2

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> { 
    ...
}

...但是这对您是否重要取决于您的用例。

于 2013-02-07T17:16:20.653 回答
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");
    }

}

这不是你想做的吗?

于 2013-02-07T17:36:44.437 回答