首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >带迭代误差的减速器

带迭代误差的减速器
EN

Stack Overflow用户
提问于 2016-07-01 21:30:22
回答 1查看 263关注 0票数 0

我在hadoop中有一个还原器,它的代码如下:

代码语言:javascript
复制
public void reduce(Text key, Iterator<Text> values, Context context) throws IOException, InterruptedException {
/*some code*/
String followers = ""; 
  while(values.hasNext()){
        followers = followers + values.next().toString() + ",";
  }
/*some code*/
}

我想为某个节点列出一个追随者列表,但是当我运行它时,我得到了以下信息:

代码语言:javascript
复制
Error: java.lang.ArrayIndexOutOfBoundsException: 1

如果值是Iterable类型,那么我没有问题,但为什么会发生这种情况呢?

提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-07-02 09:13:36

如果要扩展org.apache.hadoop.mapreduce.Reducer (Java文档),则用于reduce()的方法签名是不正确的。当您实现reduce()方法时,您将重写Reduce类中的实现。

你有:

reduce(Text key, Iterator<Text> values, Context context)

它应该是:

reduce(Text key, Iterable<Text> values, Context context)

注意IteratorIterable之间的区别。这可能意味着您的减少实际上没有被调用。

您可以将@Override注释添加到方法中,以帮助防止这种情况发生。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38154109

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档