Попытка найти сумму нечетных и четных чисел из файла чисел. (Карта Уменьшить: oop) - PullRequest
0 голосов
/ 23 апреля 2020

Я пытаюсь найти сумму нечетных и четных чисел из списка чисел, используя mapreduce. Я получаю сообщение об ошибке в одной строке моего кода.

Код выглядит следующим образом:

publi c class OddEven {

public static class TokenizerMapper
        extends Mapper<Object, Text, Text, IntWritable> {


    private Text oddsum = new Text();
    private Text evensum = new Text();
    private IntWritable num = new IntWritable();

    public void map(Object key, Text value, Context context
    ) throws IOException, InterruptedException {
        StringTokenizer itr = new StringTokenizer(value.toString(), ",");
        while (itr.hasMoreTokens()) {
            num.set(Integer.parseInt(itr.nextToken()));

            ***if (num % 2 == 0) {***
                context.write(evensum, num);
            else
                context.write(oddsum, num);
            }
        }

    }

    public static class IntSumReducer
            extends Reducer<Text, IntWritable, Text, IntWritable> {
        private IntWritable result = new IntWritable();

        public void reduce(Text key, Iterable<IntWritable> values,
                           Context context
        ) throws IOException, InterruptedException {
            int oddsum = 0;
            int evensum = 0;
            for (IntWritable val : values) {
                oddsum += val.get();
                evensum += val.get();
            }
            result.set(evensum);
            result.set(oddsum);
            context.write(key, result);
        }
    }

    public static void main(String[] args) throws Exception {
        Configuration conf = new Configuration();
        Job job = Job.getInstance(conf, "even odd");
        job.setJarByClass(OddEven.class);
        job.setMapperClass(TokenizerMapper.class);
        job.setCombinerClass(IntSumReducer.class);
        job.setReducerClass(IntSumReducer.class);
        job.setOutputKeyClass(Text.class);
        job.setOutputValueClass(IntWritable.class);
        FileInputFormat.addInputPath(job, new Path(args[0]));
        FileOutputFormat.setOutputPath(job, new Path(args[1]));
        System.exit(job.waitForCompletion(true) ? 0 : 1);
    }
}

The Error

Строка кода, которая является ошибкой: if (num% 2 == 0) И сообщение об ошибке, которое я получаю: Operator% нельзя применить к IntWritable The Error Message: Operator % cannot be applied to IntWritable, Int

Я не совсем понимаю, в чем проблема, потому что я уже преобразовал ее в целое число в предыдущей строке.

...