在我的项目中,我有多个严格排序的类型,并且我需要它们都支持范围操作 - 给定两个边界值,返回所有中间值的列表。
为了避免重复,我认为我可以创建一个类似于下面的“特征”,它将声明相应的原始操作并在其上构建范围方法。
然而,使用这样的接口,我需要按照以下方式实现操作:
当然,这是错误的。我所需要的是以下内容。
希望我要达到的目标很明确。正确的做法是什么?
为了避免重复,我认为我可以创建一个类似于下面的“特征”,它将声明相应的原始操作并在其上构建范围方法。
public interface Navigable {
public Navigable previous() throws UnsupportedOperationException;
public boolean isFirst();
public Navigable next() throws UnsupportedOperationException;
public boolean isLast();
public boolean precedes(Navigable other);
public default List<Navigable> range(Navigable to) {
Navigable from = this;
boolean invert = to.precedes(from);
if (invert) {
Navigable tmp = from;
from = to;
to = tmp;
}
List<Navigable> result = new LinkedList<>();
while (from.precedes(to)) {
result.add(from);
from = from.next();
}
result.add(to);
if (invert) {
reverse(result);
}
return result;
}
}
然而,使用这样的接口,我需要按照以下方式实现操作:
public class Item implements Navigable {
...
@Override
public boolean precedes(Navigable other) {
...
}
...
}
当然,这是错误的。我所需要的是以下内容。
public class Item implements Navigable {
...
@Override
public boolean precedes(Item other) {
...
}
...
}
希望我要达到的目标很明确。正确的做法是什么?
preceeds
应为precedes
,如果你的意思是“某物在另一物之前出现”。 - Paul Richter