zoukankan      html  css  js  c++  java
  • MapReduce中ArrayWritable 使用方法

    在编写MapReduce程序时,Map和Reduce之间传递的数据需要是ArrayList类型的,在调试运行时遇到了这样的一个错误:

    java.lang.RuntimeException: java.lang.NoSuchMethodException: org.apache.hadoop.io.ArrayWritable.<init>()
    

      

    经查询官网API文档后发现这样的一段话:

    A Writable for arrays containing instances of a class. The elements of this writable must all be instances of the same class. If this writable will be the input for a Reducer, you will need to create a subclass that sets the value to be of the proper type. For example: public class IntArrayWritable extends ArrayWritable { public IntArrayWritable() { super(IntWritable.class); } }

    原来是要自己实现一个ArrayWritable类的派生类,使用时只要实现两个构造函数即可

    public static class TextArrayWritable extends ArrayWritable {
     public TextArrayWritable() {
     super(Text.class);
     }
    
     public TextArrayWritable(String[] strings) {
     super(Text.class);
     Text[] texts = new Text[strings.length];
     for (int i = 0; i < strings.length; i++) {
     texts[i] = new Text(strings[i]);
     }
     set(texts);
     }
    }
    

    我的个人博客:http://www.yancey.info/?p=188

      

  • 相关阅读:
    thusc总结
    5.12总结
    5.9总结
    C语言学习之笔记
    C语言----------指针
    typedef , static和 extern
    数据库(mysql5.5)的一些基本的操作
    Java中基本数据类型占几个字节多少位
    java &和&& 以及 |和 ||之间的异同点
    拨开云雾见月明
  • 原文地址:https://www.cnblogs.com/yancey/p/3946513.html
Copyright © 2011-2022 走看看