MapReduce中ArrayWritable 使用指南
在编写MapReduce程序时,Map和Reduce之间传递的数据需要是ArrayList类型的,在调试运行时遇到了这样的一个错误:
java.lang.RuntimeException:java.lang.NoSuchMethodException:org.apache.hadoop.io.ArrayWritable.<init>()
经查询官网API文档后发现这样的一段话:
AWritableforarrayscontaininginstancesofaclass.Theelementsofthiswritablemustallbeinstancesofthesameclass.IfthiswritablewillbetheinputforaReducer,youwillneedtocreateasubclassthatsetsthevaluetobeofthepropertype.Forexample:publicclassIntArrayWritableextendsArrayWritable{publicIntArrayWritable(){super(IntWritable.class);}}
原来是要自己实现一个ArrayWritable类的派生类,使用时只要实现两个构造函数即可
publicstaticclassTextArrayWritableextendsArrayWritable{
publicTextArrayWritable(){
super(Text.class);
}
publicTextArrayWritable(String[]strings){
super(Text.class);
Text[]texts=newText[strings.length];
for(inti=0;i<strings.length;i++){
texts[i]=newText(strings[i]);
}
set(texts);
}
}
热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语