Mapper和Reduce代码逻辑

//自定义MyMapper类继承Mapper
public class MyMapper extends Mapper<Object, Text, Text, IntWritable>{
//定义初始次数为1
private final static IntWritable one = new IntWritable(1);
//覆写map函数
public void map(Object key, Text value, Context context) 
		throws IOException, InterruptedException{
	String line = value.toString();
	String array[] = line.split(",");//指定,为分隔符,组成数组
	String keyOutput = array[1];//提取数组中的访问日期作为key
	context.write(new Text(keyOutput), one);//组成键值对
}
}
//自定义MyReducer继承Reducer
public class MyReducer extends Reducer<Text, IntWritable,Text,IntWritable>{
private IntWritable result = new IntWritable();
//覆写reduce函数
public void reduce(Text key,Iterable<IntWritable>values,Context context)
throws IOException, InterruptedException{
	int sum = 0;//定义累加器,初始值为0
	for(IntWritable val : values) {//读取Mapper输出的键值对
		sum+=val.get();//将相同键的所有值进行累加
	}
	result.set(sum);
	context.write(key, result);//输出<访问日期,总访问次数>
}
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值