Java中的泛型生产者和消费者

Man*_*rte 3 java generics pecs

我有这个方法来检索作为给定类的实例的对象:

public class UtilitiesClass {

    public static final Collection<Animal> get(Collection<Animal> animals, Class<? extends Animal> clazz) {
        // returns the Animals which are an instanceof clazz in animals
    }
...
}
Run Code Online (Sandbox Code Playgroud)

要调用该方法,我可以这样做:

Collection<Animal> dogs = UtilitiesClass.get(animals, Dog.class);
Run Code Online (Sandbox Code Playgroud)

这很好,但我也希望能够通过以下两种方式调用该方法:

Collection<Animal> dogs = UtilitiesClass.get(animals, Dog.class);
Run Code Online (Sandbox Code Playgroud)

要么

Collection<Dog> dogsTyped = UtilitiesClass.get(animals, Dog.class);
Run Code Online (Sandbox Code Playgroud)

我的意思是我希望能够将方法的结果存储在Dog Collection或Animal one中,因为我需要Dog.class扩展Animal.class

我在考虑这样的事情:

public static final <T> Collection<T> get(Class<T extends Animal> clazz) {
    // returns the Animals which are an instanceof clazz
}
Run Code Online (Sandbox Code Playgroud)

但它不起作用.任何提示?

编辑:最后,使用@Rohit Jain答案,这是调用UtilitiesClass方法时的解决方案:

Collection<? extends Animal> dogsAnimals = UtilitiesClass.get(animals, Dog.class);
Collection<Dog> dogs = UtilitiesClass.get(animals, Dog.class);
Run Code Online (Sandbox Code Playgroud)

Roh*_*ain 5

是的,你必须使方法通用.并且在声明类型参数时应该给出界限:

public static final <T extends Animal> Collection<T> get(
                   Collection<Animal> animals, Class<T> clazz) {
}
Run Code Online (Sandbox Code Playgroud)

但是,在将animalfrom animals集合添加到new时Collection<T>,您必须将其强制转换为clazztype.你需要Class#isInstance(Object)方法和Class#cast(Object)方法.