这是一些get()
方法的枚举。
public class ZooTest {
public enum Animals {
CHLOE("cat"),
MOLLY("dog"),
LUNA("cat"),
TOBY("dog"),
ZOE("parrot"),
SNICKERS("cat");
private final String type;
Animals(String type) {
this.type = type;
}
public class Animal {
}
public class Cat extends Animal {
}
public class Dog extends Animal {
}
public class Parrot extends Animal {
}
public Animal get() {
return "cat".equals(type)
? new Cat()
: "dog".equals(type)
? new Dog()
: new Parrot();
}
}
@Test
public void shouldReturnSpecificClass() {
assertTrue(Animals.CHLOE.get() instanceof Cat);
}
@Test(expectedExceptions = {ClassCastException.class})
public void shouldReturnSpecificClass2() {
Dog dog = (Dog) Animals.CHLOE.get();
}
}
问题是如何在不使用枚举外的类型铸造的情况下返回特定类型的动物。当然我可以使用像
这样的方法public <T extends Animal> T get(Class<T> clazz) { return (T) get(); }
但也许没有那么笨拙的方式。
答案 0 :(得分:2)
您可以创建一个抽象方法get
,并且每个动物实例都必须实现:
public enum Animals {
CHLOE("cat") {
@Override
public Animal get() { return new Cat(); }
},
MOLLY("dog") {
@Override
public Animal get() { return new Dog(); }
}
//... and so on
public abstract Animal get();
}
答案 1 :(得分:2)
此答案基于以下假设:您实际上并不需要CHLOE,LUNA或SNICKERS的Cat
单独实例。此外,由于你的动物没有任何方法或状态,它看起来并不像你需要它们作为单独的类。所以也许这样的事情会更容易:
public enum AnimalType {
Cat, Dog, Parrot;
}
public enum Animals {
CHLOE(AnimalType.Cat),
MOLLY(AnimalType.Dog),
LUNA(AnimalType.Cat),
TOBY(AnimalType.Dog),
ZOE(AnimalType.Parrot),
SNICKERS(AnimalType.Cat);
private final AnimalType type;
Animals(AnimalType type) {
this.type = type;
}
public AnimalType get() {
return type;
}
}
答案 2 :(得分:0)
你有两个使用枚举的错误。第一个枚举实体必须提供类型而不是实例(它如何指向 Quirliom ),然后你的动物枚举必须包含成员猫,狗等。第二个遗憾的是你不能从枚举中扩展任何类。