我正在尝试创建一个自定义迭代器,但由于没有可用的教程,我查看了 Accumulo github 页面上提供的代码。
在那里我发现所有类都实现了 SortedKeyValueIterator 并覆盖了它的功能。
这些函数的作用是什么,在创建实现 SortedKeyValueIterator 的新类时重写这些函数时应该采用什么方法。
这是我试图理解的 RowFilter 类的示例代码。
public void init(SortedKeyValueIterator<Key,Value> source, Map<String,String> options, IteratorEnvironment env) throws IOException {
super.init(source, options, env);
this.decisionIterator = new RowIterator(source.deepCopy(env));
}
public SortedKeyValueIterator<Key,Value> deepCopy(IteratorEnvironment env) {
RowFilter newInstance;
try {
newInstance = getClass().newInstance();
} catch (Exception e)
{
throw new RuntimeException(e);
}
newInstance.setSource(getSource().deepCopy(env));
newInstance.decisionIterator = new RowIterator(getSource().deepCopy(env));
return newInstance;
}
我想知道,这段代码做了什么,如果我想要另一个类来实现 SortedKeyValueIterator,我应该如何覆盖这些函数。