hadoop自定义类型异常java.lang.RuntimeException: java.lang.NoSuchMethodException: twicesort.TwoKey.<init>()
来源:互联网 发布:淘宝红搜是什么意思 编辑:程序博客网 时间:2024/06/06 13:14
java.lang.RuntimeException: java.lang.NoSuchMethodException: twicesort.TwoKey.<init>() at org.apache.hadoop.util.ReflectionUtils.newInstance(ReflectionUtils.java:131) at org.apache.hadoop.io.WritableComparator.newKey(WritableComparator.java:144) at org.apache.hadoop.io.WritableComparator.<init>(WritableComparator.java:130) at org.apache.hadoop.io.WritableComparator.get(WritableComparator.java:65) at org.apache.hadoop.mapred.JobConf.getOutputKeyComparator(JobConf.java:887) at org.apache.hadoop.mapred.MapTask$MapOutputBuffer.init(MapTask.java:1001) at org.apache.hadoop.mapred.MapTask.createSortingCollector(MapTask.java:401) at org.apache.hadoop.mapred.MapTask.access$100(MapTask.java:81) at org.apache.hadoop.mapred.MapTask$NewOutputCollector.<init>(MapTask.java:695) at org.apache.hadoop.mapred.MapTask.runNewMapper(MapTask.java:767)
重点在这里,java.lang.NoSuchMethodException: twicesort.TwoKey,他说没有这个方法,这个方法是TwoKey的无参构造方法
这个细节在hadoop权威指南上也有提到,就在序列化或者自定义类型那章,具体不记得了,我的理解是首先他反序列化的时候先要拿到一个无参的构造对象,然后再进行对象内值的填充。
让我们再来看看hadoop给我提供的类型是不是都有无参的构造方法
public class IntWritable implements WritableComparable<IntWritable> { private int value; public IntWritable() {} public IntWritable(int value) { set(value); } }
public class LongWritable implements WritableComparable<LongWritable> { private long value; public LongWritable() {} public LongWritable(long value) { set(value); } }
public class Text extends BinaryComparable implements WritableComparable<BinaryComparable> { public Text() { bytes = EMPTY_BYTES; } /** Construct from a string. */ public Text(String string) { set(string); } /** Construct from another text. */ public Text(Text utf8) { set(utf8); } /** Construct from a byte array. */ public Text(byte[] utf8) { set(utf8); } }
public class BooleanWritable implements WritableComparable<BooleanWritable> { private boolean value; /** */ public BooleanWritable() {}; }
public class ByteWritable implements WritableComparable<ByteWritable> { private byte value; public ByteWritable() {} public ByteWritable(byte value) { set(value); } }
public class ShortWritable implements WritableComparable<ShortWritable> { private short value; public ShortWritable() { } public ShortWritable(short value) { set(value); }}
阅读全文
0 0
- hadoop自定义类型异常java.lang.RuntimeException: java.lang.NoSuchMethodException: twicesort.TwoKey.<init>()
- hadoop java.lang.RuntimeException: java.lang.NoSuchMethodException
- java.lang.RuntimeException: java.lang.NoSuchMethodException: tfidf$Reduce.<init>()
- java.lang.NoSuchMethodException <init>()
- hadoop(mapreduce):java.lang.NoSuchMethodException: ******Mapper.<init>()
- java.lang.RuntimeException:java.lang.NoSuchMethodException: *.*.Maper
- java.lang.NoSuchMethodException异常
- hadoop java.lang.Exception: java.lang.RuntimeException: java.lang.NoSuchMethodException: log_analys
- mapreduce java.lang.Exception: java.lang.RuntimeException: java.lang.NoSuchMethodException
- Hadoop 学习笔记:java.lang.NoSuchMethodException: DataJoin$TaggedWritable.<init>()
- 类型转换异常处理java.lang.RuntimeException
- struts2:java.lang.NoSuchMethodException异常
- java.lang.NoSuchMethodException 异常总结
- java.lang.NoSuchMethodException异常解决
- struts2 java.lang.NoSuchMethodException异常
- java.lang.NoSuchMethodException异常解决
- java.lang.NoSuchMethodException:构造函数<init>失败
- 报错 :java.lang.NoSuchMethodException: <init>()
- 实验二单链表的实现
- 01动态规划基础---最长递增子序列长度
- python 问题定期总结
- jsp与servlet的区别
- XTU 1268 鞍点
- hadoop自定义类型异常java.lang.RuntimeException: java.lang.NoSuchMethodException: twicesort.TwoKey.<init>()
- YUM实现LAMP
- bzoj 1568: [JSOI2008]Blue Mary开公司
- 一个日志查看工具的设想。
- 模板(线段树 + 树状数组 + 区间修改 + 区间查询)eg:POJ 3468
- 剑指offer_数组---数组中只出现一次的数字
- 我是如何做IT的
- 计算机网络作业三
- java字符串处理