我知道使用执行程序而不是ThreadGroup的当前做法:
但是,这样 的ThreadGroup 固有的 缺陷是 什么(我听过对该类的模糊批评)?
感谢您的回答。
PS。这似乎无法回答这个问题。
这在《有效的Java第二版》中进行了解释。,项目73。
最初将线程组设想为一种出于安全目的隔离小程序的机制。他们从来没有真正兑现过这个诺言,其安全重要性已经下降到在Java安全模型[Gong03]的标准工作中甚至没有提到的程度。
具有讽刺意味的
ThreadGroup
是,从线程安全的角度来看,API较弱。要获取线程组中活动线程的列表,必须调用该enumerate
方法,该方法将一个足以容纳所有活动线程的数组作为参数。该activeCount
方法返回线程组中活动线程的数量,但是不能保证一旦分配了数组并将其传递给该enumerate
方法后,此计数仍将是准确的。如果线程数增加并且数组太小,则该enumerate
方法将无提示地忽略数组中没有空间的所有线程。列出线程组子组的API同样存在缺陷。尽管可以通过添加新方法来解决这些问题,但由于没有真正的需要,因此没有解决这些问题: 线程组已过时 。
在1.5版之前,只有
ThreadGroup
API 提供一小部分功能:ThreadGroup.uncaughtException
当线程引发未捕获的异常时,该方法是获得控制权的唯一方法。例如,此功能可用于将堆栈跟踪定向到特定于应用程序的日志。但是,从1.5版开始,Thread
的setUncaughtExceptionHandler
方法可以使用相同的功能。总而言之,线程组没有提供有用功能的方式,它们提供的许多功能都有缺陷。最好将线程组视为不成功的实验,您应该完全忽略它们的存在。如果设计一个处理逻辑线程组的类,则可能应该使用线程池执行程序(项目68)。
主要内容:1 Java.lang ThreadGroup介绍,2 Java.lang ThreadGroup声明,3 Java.lang ThreadGroup方法,4 Java.lang ThreadGroup案例1 Java.lang ThreadGroup介绍 java.lang.ThreadGroup 类表示一组线程。它也可以包括其它的线程组。线程组构成一棵树,除了初始线程组中的每个线程组都有一个父类。 2 Java.lang ThreadGroup声明 3 Java.lang Thre
问题内容: 为什么是选择?如果添加了想要的新列,这是否意味着更少的代码更改? 我知道这在某些数据库上是性能问题,但是如果您真的想要每列,该怎么办? 问题答案: 确实有三个主要原因: 将数据转移到消费者方面效率低下。 当您选择SELECT *时,通常从数据库中检索到的列数超出了应用程序实际需要运行的列数。这将导致更多数据从数据库服务器移至客户端,从而减慢访问速度并增加计算机上的负载,并花费更多时间在
问题内容: 假设我们在页面上有一个DIV ,并且想要将该DIV的内容复制(“复制粘贴”)到另一个DIV中。我们可以这样做: 或使用jQuery: 但是,看来此方法不是一个好主意,应避免使用。 (1)为什么要避免这种方法? (2)应该怎么做呢? 更新: 为了解决这个问题,我们假设DIV中没有ID为ID的元素。 (对不起,我忘了在原始问题中介绍此案。) 结论: 我已经在下面发布了我对这个问题的答案(如
问题内容: 我想问问为什么Java注释使用了这么多…我知道它们在例如jpa中替换了xml配置,但是为什么要使用这种配置呢?考虑这段代码: 现在,当我尝试使用的persist方法将其置于持久性上下文中时,尝试持久化实例会遇到运行时错误(最好是出现编译错误)。对我来说,有一个明显的解决方案,强制实体实现某种无方法接口,而不是使用@Annotations。但这在框架设计人员中并不流行,此解决方案的缺点是
这是一段代码 这将向控制台提供以下结果: 这意味着第一个中的链被识别为空链。 另一方面,Reactor具有以下类MonoEmpty,该类由Mono返回。empty()方法。除此之外,该方法还包括以下内容: 没有发出任何项,但我用方法发出了类型化对象。 对此有何解释?
我有一个简单的批处理测试文件test.bat如下行: 当我运行它时,我希望得到的是测试,而不是: 为什么batch会试图解释这条评论?或者这里发生了什么?如果我去掉注释,脚本会按预期打印测试。 文件中也没有提到这一点。