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 删除。