Java泛型问题

时间:2010-01-19 20:29:50

标签: java generics

我正在实现一个高阶拆分函数,它接受一个要拆分的项集合,一个定义拆分边界条件的过滤器委托,以及两个ReturnDelegate,它们是提供具体集合类型的委托。返回集合(因此我不需要在split函数中修复ArrayList或HashSet,而是将返回集合的创建留给调用代码,从而产生灵活性)。返回是一个Tuple2类,它基本上是两个异构对象的包装器。

这是拆分方法:

public static <T, T1 extends Collection<T>, T2 extends Collection<T>>
    Tuple2<T1, T2> split(final Collection<T> coll,
                         final FilterDelegate<T> filterDelegate,
                         final FilterReturnDelegate<T1> truthyDelegate1,
                         final FilterReturnDelegate<T2> falsyDelegate2) {
    final Collection<T> t1 = truthyDelegate1.createReturnCollection();
    final Collection<T> t2 = falsyDelegate2.createReturnCollection();

    for (final T item : coll) {
        if (filterDelegate.filter(item)) {
            t1.add(item);
        } else {
            t2.add(item);
        }
    }

    final Tuple2<T1, T2> retval = new Tuple2<T1, T2>();
    retval.setItem1(t1);
    retval.setItem2(t2);

    return retval;
}

这是Tuple2类。它是异构对象的简单通用感知包装器。

public final class Tuple2<T1, T2> {

    private T1 _item1;

    private T2 _item2;

    public Tuple2() {
    }

    public Tuple2(final T1 item1, final T2 item2) {
        _item1 = item1;
        _item2 = item2;
    }

    public T1 getItem1() {
        return _item1;
    }

    public T2 getItem2() {
        return _item2;
    }

    public void setItem1(final T1 item1) {
        _item1 = item1;
    }

    public void setItem2(final T2 item2) {
        _item2 = item2;
    }

}

FilterDelegate:

public interface FilterDelegate<T> {

    /**
     *
     * @param item The item to be filtered.
     * @return true if the item should be retained. false if the item should be
     */
    boolean filter(T item);

}

FilterReturnDelegate:

public interface FilterReturnDelegate<R extends Collection<?>> {

    R createReturnCollection();

}

但是,上面的拆分方法甚至都没有编译。 Javac在线上抱怨

retval.setItems(t1); retval.setItems(t2);

"The method setItem1(T1) in the type Tuple2<T1,T2> is not applicable for the arguments (Collection<T>)"

想知道我在这里做错了什么?

1 个答案:

答案 0 :(得分:3)

您的t1t2类型应为T1T2

final T1 t1 = truthyDelegate1.createReturnCollection();
final T2 t2 = falsyDelegate2.createReturnCollection();

Collection<T>不是T1的子类型,因此setItem(t1)会失败。