annotate src/goodjava/util/MapReduce.java @ 2172:75c45f1a743e default tip

MapReduce cleanup
author Franklin Schmidt <fschmidt@gmail.com>
date Sun, 22 Mar 2026 20:58:17 -0600
parents 8b77bd42864d
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2171
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
1 package goodjava.util;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
2
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
3 import java.util.Collections;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
4 import java.util.List;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
5 import java.util.ArrayList;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
6 import java.util.Map;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
7 import java.util.HashMap;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
8 import java.util.WeakHashMap;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
9 import java.util.Set;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
10
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
11
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
12 public class MapReduce {
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
13
2172
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
14 public interface Handler {
2171
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
15 public List map(Object arg);
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
16 public List reduce(List<List> lists);
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
17 }
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
18
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
19 private static Map<String,MapReduce> instances = new HashMap<String,MapReduce>();
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
20
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
21 // an active handler will be arbitrarily chosen for reduce
2172
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
22 public static synchronized MapReduce register(String key,Handler handler) {
2171
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
23 MapReduce mr = instances.get(key);
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
24 if( mr == null ) {
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
25 mr = new MapReduce();
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
26 instances.put(key,mr);
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
27 }
2172
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
28 mr.handlers.add(handler);
2171
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
29 return mr;
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
30 }
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
31
2172
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
32 private Set<Handler> handlers = Collections.newSetFromMap(new WeakHashMap<Handler, Boolean>());
2171
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
33
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
34 public List run(Object arg) {
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
35 List<List> lists = new ArrayList<List>();
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
36 Handler lastHandler = null;
2172
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
37 Handler[] snapshot = handlers.toArray(new Handler[0]);
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
38 for( Handler h : snapshot ) {
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
39 lists.add( h.map(arg) );
75c45f1a743e MapReduce cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 2171
diff changeset
40 lastHandler = h;
2171
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
41 }
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
42 return lastHandler==null ? Collections.emptyList() : lastHandler.reduce(lists);
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
43 }
8b77bd42864d add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
44 }