Thinking in java笔记: 关于thread group
Thread groups are best viewed as an unsuccessful experiment , and you may simply ignore their existence.
Thread groups最好被看作是一个没有成功的实验品,最好忽略它。
Why:
在Effective Java 2nd ed,Item 73解释了这个问题
线程组最初被设计为安全的考虑隔离applets。它们从来没有真正达到这个目标,而且在java安全模型中都一点没有提到。
具有讽刺意味的是,线程组API从线程安全角度来看是很弱的。比如说,获取线程组中活跃的线程个数,你必须调用enumrate方法(采用一个够大的数组来存储活跃的线程数)。并且返回的这个活跃数不能保证是精确的。如果数组已经分配完毕,但是线程个数增加了额,group只是简单的默默忽略这些装不下的线程。
查看线程组下子线程组也是比较有缺陷的。这些方法本来可以使用新方法进行弥补,但是他们并没有增加,因为实在没有需要:线程组都是隔离的。
在1.5之前,有一个功能是比较有用的。就是ThreadGroup.uncaughtExcept方法。这个功能是比较有用的,用来记录specific log日志。然后在1.5功能之后,相似的功能也出现了。
总结来说,线程组没有提供很有用的功能,而且提供的功能也是缺陷的。线程组最好被当作没成功的经验,最好忽略它。如果你需要一个逻辑上的线程组,那么最好使用是线程池。