Mercurial Hosting > luan
annotate 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 |
| 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 |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
14 public interface Mapper { |
|
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 } |
|
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 public interface Handler extends Mapper { |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
19 public List reduce(List<List> lists); |
|
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 |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
22 private static Map<String,MapReduce> instances = new HashMap<String,MapReduce>(); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
23 |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
24 // an active handler will be arbitrarily chosen for reduce |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
25 public static synchronized MapReduce register(String key,Mapper mapper) { |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
26 MapReduce mr = instances.get(key); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
27 if( mr == null ) { |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
28 mr = new MapReduce(); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
29 instances.put(key,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 mr.mappers.add(mapper); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
32 return mr; |
|
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 |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
35 private Set<Mapper> mappers = Collections.newSetFromMap(new WeakHashMap<Mapper, Boolean>()); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
36 |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
37 public List run(Object arg) { |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
38 List<List> lists = new ArrayList<List>(); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
39 Handler lastHandler = null; |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
40 Mapper[] snapshot = mappers.toArray(new Mapper[0]); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
41 for( Mapper m : snapshot ) { |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
42 lists.add( m.map(arg) ); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
43 if( m instanceof Handler ) |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
44 lastHandler = (Handler)m; |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
45 } |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
46 return lastHandler==null ? Collections.emptyList() : lastHandler.reduce(lists); |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
47 } |
|
8b77bd42864d
add add Thread.map_reduce
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff
changeset
|
48 } |
