如何包装java.util.Iterator以更改正在迭代的对象的类型
发布时间:2020-12-15 04:43:17 所属栏目:Java 来源:网络整理
导读:我正在为第三方API提供一些外观类,我需要包装一个迭代器,以便我可以替换用我自己的外观对象迭代的东西. 这是我的facade类的简化版本,它包装了一个名为Item的API类 class FacadeItem { Item item; FacadeItem(Item item) { this.item = item; }} API提供此形
|
我正在为第三方API提供一些外观类,我需要包装一个迭代器,以便我可以替换用我自己的外观对象迭代的东西.
这是我的facade类的简化版本,它包装了一个名为Item的API类 class FacadeItem {
Item item;
FacadeItem(Item item) {
this.item = item;
}
}
API提供此形式的迭代器Iterator< Item> 我需要实现这个形式的迭代器Iterator< FacadeItem>由API的迭代器支持. 我考虑使用Guava库中的ForwardingIterator如下: class FacadeItemIterator<FacadeItem> extends ForwardingIterator<Item> {
final Iterator<Item> delegate; // backing iterator
FacadeItemIterator(Iterator<Item> delegate) {
this.delegate = delegate;
}
@Override protected Iterator<Item> delegate() {
return delegate;
}
@Override
public FacadeItem next() {
return new FacadeItem(super.next());
}
}
但是编译器不允许覆盖next(),因为它期望返回的类型是Item,而不是FacadeItem 解决方法
Iterator接口不是那么大,所以你可以编写自己的委托迭代器:
class FacadeIterator implements Iterator<FacadeItem> {
private final Iterator<Item> delegate; // set in ctor
@Override
public FacadeItem next() {
return new FacadeItem(delegate.next());
}
// the other two methods just delegate straight
}
然后 Iterator<FacadeItem> facadeIterator = new FacadeIterator(itemIterator); 如果你正在使用Guava,你可以使用他们的 Iterator<FacadeItem> facadeIterator = Iterators.transform(itemIterator,/* anon class of Function<Item,FacadeItem> */); 在Java 1.8中,这个选项变得非常简单: Iterator<FacadeItem> facadeIterator
= Iterators.transform(itemIterator,FacadeItem::new)
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
