84669 人學習
152542 人學習
20005 人學習
5487 人學習
7821 人學習
359900 人學習
3350 人學習
180660 人學習
48569 人學習
18603 人學習
40936 人學習
1549 人學習
1183 人學習
32909 人學習
文档上只有得到 当前运行的线程数量
我要获得正在运行的,我放进去的runable的实例 怎么得到
API层面应该没有这种支持. 有一个可能的办法, 覆写ThreadPoolExecutor的beforeExecute和afterExecute方法, 可以在 task执行前/后 去写log文件, 你的监测进程/线程去 轮询log得到当前在运行的task.
或者你可以用一些线程/进程间通讯的 方式(比如socket?), 可以得到更实时的结果.
的确可以覆盖 beforeExecute 和 afterExecute ,然后可以再开一个共享的 ConcurrentHashMap ,beforeExecute 里面把 Runnable 放进 HashMap,afterExecute 把 Runnable 从 HashMap 删除。
API层面应该没有这种支持. 有一个可能的办法, 覆写ThreadPoolExecutor的beforeExecute和afterExecute方法, 可以在 task执行前/后 去写log文件, 你的监测进程/线程去 轮询log得到当前在运行的task.
或者你可以用一些线程/进程间通讯的 方式(比如socket?), 可以得到更实时的结果.
的确可以覆盖 beforeExecute 和 afterExecute ,然后可以再开一个共享的 ConcurrentHashMap ,beforeExecute 里面把 Runnable 放进 HashMap,afterExecute 把 Runnable 从 HashMap 删除。