view src/goodjava/util/MapReduce.java @ 2171:8b77bd42864d

add add Thread.map_reduce
author Franklin Schmidt <fschmidt@gmail.com>
date Sun, 22 Mar 2026 19:24:52 -0600
parents
children 75c45f1a743e
line wrap: on
line source

package goodjava.util;

import java.util.Collections;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.util.HashMap;
import java.util.WeakHashMap;
import java.util.Set;


public class MapReduce {

	public interface Mapper {
		public List map(Object arg);
	}

	public interface Handler extends Mapper {
		public List reduce(List<List> lists);
	}

	private static Map<String,MapReduce> instances = new HashMap<String,MapReduce>();

	// an active handler will be arbitrarily chosen for reduce
	public static synchronized MapReduce register(String key,Mapper mapper) {
		MapReduce mr = instances.get(key);
		if( mr == null ) {
			mr = new MapReduce();
			instances.put(key,mr);
		}
		mr.mappers.add(mapper);
		return mr;
	}

	private Set<Mapper> mappers = Collections.newSetFromMap(new WeakHashMap<Mapper, Boolean>());

	public List run(Object arg) {
		List<List> lists = new ArrayList<List>();
		Handler lastHandler = null;
		Mapper[] snapshot = mappers.toArray(new Mapper[0]);
		for( Mapper m : snapshot ) {
			lists.add( m.map(arg) );
			if( m instanceof Handler )
				lastHandler = (Handler)m;
		}
		return lastHandler==null ? Collections.emptyList() : lastHandler.reduce(lists);
	}
}