345
|
1 package alice.codesegment;
|
|
2
|
|
3 import java.util.concurrent.LinkedBlockingQueue;
|
|
4 import java.util.concurrent.ThreadPoolExecutor;
|
|
5 import java.util.concurrent.TimeUnit;
|
|
6
|
|
7 import org.apache.log4j.Logger;
|
|
8
|
|
9 public class CodeSegmentManager {
|
|
10
|
|
11 private static CodeSegmentManager instance = new CodeSegmentManager();
|
|
12 private ThreadPoolExecutor codeSegmentExecutor = new ThreadPoolExecutor(Runtime.getRuntime().availableProcessors(), // initial number of threads
|
|
13 Runtime.getRuntime().availableProcessors(),
|
|
14 Integer.MAX_VALUE, // keepAliveTime
|
|
15 TimeUnit.SECONDS,
|
|
16 new LinkedBlockingQueue<Runnable>());
|
|
17 private Logger logger = Logger.getLogger(CodeSegmentManager.class);
|
|
18
|
|
19 public static CodeSegmentManager get() {
|
|
20 return instance;
|
|
21 }
|
|
22
|
|
23 public static void submit(CodeSegment cs) {
|
|
24 CodeSegmentManager csManager = CodeSegmentManager.get();
|
|
25 csManager.codeSegmentExecutor.execute(cs);
|
|
26 if (csManager.logger.isDebugEnabled()) {
|
|
27 csManager.logger.debug(cs.getClass().getName());
|
|
28 }
|
|
29 }
|
|
30
|
|
31 }
|