我正在实现一个高阶拆分函数,它接受一个要拆分的项集合,一个定义拆分边界条件的过滤器委托,以及两个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>)"
。
想知道我在这里做错了什么?
答案 0 :(得分:3)
您的t1
和t2
类型应为T1
和T2
:
final T1 t1 = truthyDelegate1.createReturnCollection();
final T2 t2 = falsyDelegate2.createReturnCollection();
Collection<T>
不是T1
的子类型,因此setItem(t1)
会失败。