【发布时间】:2015-07-13 18:16:55
【问题描述】:
我想知道 Executors 类的这两种方法有什么区别?我有一个 Web 应用程序,我每 100 毫秒检查一次数据,这就是为什么我将这个调度程序与 scheduleWithFixedDelay 方法一起使用。我想知道在这种情况下我应该使用哪种方法(newScheduledThreadPool 或 newSingleThreadScheduledExecutor)? 我还有一个问题——在我监控 Glassfish 服务器的 VisualVM 中,我注意到我有一些线程处于 PARK 状态——例如:
java.lang.Thread.State: WAITING
at sun.misc.Unsafe.park(Native Method)
- parking to wait for <3cb9965d> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2039)
at java.util.concurrent.ScheduledThreadPoolExecutor$DelayedWorkQueue.take(ScheduledThreadPoolExecutor.java:1088)
at java.util.concurrent.ScheduledThreadPoolExecutor$DelayedWorkQueue.take(ScheduledThreadPoolExecutor.java:809)
at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1067)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1127)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
这些线程是否可能与调度程序连接,因为我不知道还有什么会创建它们?这些线程永远不会被破坏,所以我担心这会引起一些麻烦。这是一个屏幕截图(新的 Thread-35 将在 15 分钟内创建,依此类推...):
【问题讨论】:
-
线程池是一个线程池/线程组,具有预先配置的线程数(开始时)。如果您有一个工作密集型场景,其中池中的每个线程可能工作更长的时间并且您希望更快地完成工作,因此您创建一个线程池,这很有用。单线程——顾名思义,就是一个线程一遍又一遍地执行。根据工作性质和任务的复杂性,您可以在单个线程或线程池之间进行选择。
标签: java