我是Hadoop和Java的新手。我的映射器输出文本和Arraywritable。我在读取ArrayWritable值时遇到麻烦。将.get()值强制转换为整数。映射器和化简器代码已附加。有人可以帮助我更正我的reducer代码以读取ArrayWritable值吗?
public static class Temp2Mapper extends Mapper<LongWritable, Text, Text, ArrayWritable>{
    private static final int MISSING=9999;
    @Override public void map(LongWritable key, Text value, Context context) throws IOException, InterruptedException{
        String line = value.toString();
        String date = line.substring(07,14);
        int maxTemp,minTemp,avgTemp;
        IntArrayWritable carrier = new IntArrayWritable();
        IntWritable innercarrier[] = new IntWritable[3];
        maxTemp=Integer.parseInt(line.substring(39,45));
        minTemp=Integer.parseInt(line.substring(47,53));
        avgTemp=Integer.parseInt(line.substring(63,69));
        if (maxTemp!= MISSING)
        innercarrier[0]=new IntWritable(maxTemp); // maximum Temperature
        if (minTemp!= MISSING)
        innercarrier[1]=new IntWritable(minTemp); //minimum temperature
        if (avgTemp!= MISSING)
        innercarrier[2]=new IntWritable(avgTemp); // average temperature of 24 hours
        carrier.set(innercarrier);
        context.write(new Text(date), carrier); // Output Text and ArrayWritable
        }
}
public static class Temp2Reducer
extends Reducer<Text, ArrayWritable, Text, IntWritable>{
@Override public void reduce(Text key, Iterable<ArrayWritable> values, Context context ) 
            throws IOException, InterruptedException {
          int max = Integer.MIN_VALUE;
          int[] arr= new int[3];
          for (ArrayWritable val : values) {
              arr = (Int) val.get(); // Error: cannot cast Writable to int
              max = Math.max(max, arr[0]);
          }
          context.write( key, new IntWritable(max) );
        }
}
ArrayWritable#get方法返回的数组Writable。
您无法将转换Writable为int。您可以做的是:
Writable数组的每个项目(类型为)强制转换为IntWritableint值。Run Code Online (Sandbox Code Playgroud)for (ArrayWritable val: values) { for (Writable writable: val.get()) { // iterate IntWritable intWritable = (IntWritable)writable; // cast int value = intWritable.get(); // get // do your thing with int value } }
| 归档时间: | 
 | 
| 查看次数: | 6246 次 | 
| 最近记录: |