分叉/加入JavaEE应用程序?

我知道在 JavaEE应用程序中分离线程是一个很大的禁忌.但是,我有一个应用程序是 Java’s fork/join mechanism的完美候选.但是,由于线程不应该在应用程序中创建,有没有办法在我的EJB中使用它?我知道在WebSphere应用程序中,异步bean功能提供了这一功能.但是,我的应用程序部署在JBoss EAP 6.1上,所以这不是一个选项.

在JavaEE应用程序中是否有“合法”的方法来完成fork / join?

解决方法

现在最好的答案是Java EE 7规范中的Concurrency Utils API.您有ManagedExecutors和ManagedThreadPools.由于这些托管线程功能和托管任务由应用程序服务器控制,因此请确保您的fork连接计算使用这些资源,然后您可以确保包含线程而不是孤立线程.

最后,您可能必须编写一个“Managed”的ForkJoinPool版本才能获得最佳解决方案.但是它应该是可能的,因为作为第一步,将使用托管版本替换线程池执行程序.

PS:Java SE 8必须在Java SE 8发布时解决这个问题!

相关文章

Java中的String是不可变对象 在面向对象及函数编程语言中,不...
String, StringBuffer 和 StringBuilder 可变性 String不可变...
序列化:把对象转换为字节序列的过程称为对象的序列化. 反序...
先说结论,是对象!可以继续往下看 数组是不是对象 什么是对...
为什么浮点数 float 或 double 运算的时候会有精度丢失的风险...
面试题引入 这里引申出一个经典问题,看下面代码 Integer a ...