| 
 | The Spring Framework | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.springframework.scheduling.backportconcurrent.ThreadPoolTaskExecutor
public class ThreadPoolTaskExecutor
JavaBean that allows for configuring a JSR-166 backport
 ThreadPoolExecutor in bean
 style (through its "corePoolSize", "maxPoolSize", "keepAliveSeconds", "queueCapacity"
 properties), exposing it as a Spring TaskExecutor.
 This is an alternative to configuring a ThreadPoolExecutor instance directly using
 constructor injection, with a separate ConcurrentTaskExecutor adapter wrapping it.
 
For any custom needs, in particular for defining a
 ScheduledThreadPoolExecutor,
 it is recommended to use a straight definition of the Executor instance or a
 factory method definition that points to the JSR-166 backport
 Executors class.
 To expose such a raw Executor as a Spring TaskExecutor,
 simply wrap it with a ConcurrentTaskExecutor adapter.
 
NOTE: This class implements Spring's
 TaskExecutor interface as well as
 the JSR-166 Executor
 interface, with the former being the primary interface, the other just
 serving as secondary convenience. For this reason, the exception handling
 follows the TaskExecutor contract rather than the Executor contract, in
 particular regarding the TaskRejectedException.
TaskExecutor, 
Executor, 
ThreadPoolExecutor, 
ScheduledThreadPoolExecutor, 
Executors, 
ConcurrentTaskExecutor| Field Summary | |
|---|---|
| protected  Log | logger | 
| Constructor Summary | |
|---|---|
| ThreadPoolTaskExecutor() | |
| Method Summary | |
|---|---|
|  void | afterPropertiesSet()Calls initialize()after the container applied all property values. | 
| protected  edu.emory.mathcs.backport.java.util.concurrent.BlockingQueue | createQueue(int queueCapacity)Create the BlockingQueue to use for the ThreadPoolExecutor. | 
|  void | destroy()Calls shutdownwhen the BeanFactory destroys
 the task executor instance. | 
|  void | execute(Runnable task)Implementation of both the JSR-166 backport Executor interface and the Spring TaskExecutor interface, delegating to the ThreadPoolExecutor instance. | 
|  int | getActiveCount()Return the number of currently active threads. | 
|  int | getCorePoolSize()Return the ThreadPoolExecutor's core pool size. | 
|  int | getKeepAliveSeconds()Return the ThreadPoolExecutor's keep-alive seconds. | 
|  int | getMaxPoolSize()Return the ThreadPoolExecutor's maximum pool size. | 
|  int | getPoolSize()Return the current pool size. | 
|  edu.emory.mathcs.backport.java.util.concurrent.ThreadPoolExecutor | getThreadPoolExecutor()Return the underlying ThreadPoolExecutor for native access. | 
|  void | initialize()Creates the BlockingQueue and the ThreadPoolExecutor. | 
|  boolean | prefersShortLivedTasks()This task executor prefers short-lived work units. | 
|  void | setBeanName(String name)Set the name of the bean in the bean factory that created this bean. | 
|  void | setCorePoolSize(int corePoolSize)Set the ThreadPoolExecutor's core pool size. | 
|  void | setKeepAliveSeconds(int keepAliveSeconds)Set the ThreadPoolExecutor's keep-alive seconds. | 
|  void | setMaxPoolSize(int maxPoolSize)Set the ThreadPoolExecutor's maximum pool size. | 
|  void | setQueueCapacity(int queueCapacity)Set the capacity for the ThreadPoolExecutor's BlockingQueue. | 
|  void | setRejectedExecutionHandler(edu.emory.mathcs.backport.java.util.concurrent.RejectedExecutionHandler rejectedExecutionHandler)Set the RejectedExecutionHandler to use for the ThreadPoolExecutor. | 
|  void | setThreadFactory(edu.emory.mathcs.backport.java.util.concurrent.ThreadFactory threadFactory)Set the ThreadFactory to use for the ThreadPoolExecutor's thread pool. | 
|  void | shutdown()Perform a shutdown on the ThreadPoolExecutor. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
protected final Log logger
| Constructor Detail | 
|---|
public ThreadPoolTaskExecutor()
| Method Detail | 
|---|
public void setCorePoolSize(int corePoolSize)
This setting can be modified at runtime, for example through JMX.
public int getCorePoolSize()
public void setMaxPoolSize(int maxPoolSize)
Integer.MAX_VALUE.
 This setting can be modified at runtime, for example through JMX.
public int getMaxPoolSize()
public void setKeepAliveSeconds(int keepAliveSeconds)
This setting can be modified at runtime, for example through JMX.
public int getKeepAliveSeconds()
public void setQueueCapacity(int queueCapacity)
Integer.MAX_VALUE.
 Any positive value will lead to a LinkedBlockingQueue instance; any other value will lead to a SynchronousQueue instance.
LinkedBlockingQueue, 
SynchronousQueuepublic void setThreadFactory(edu.emory.mathcs.backport.java.util.concurrent.ThreadFactory threadFactory)
Executors.defaultThreadFactory()public void setRejectedExecutionHandler(edu.emory.mathcs.backport.java.util.concurrent.RejectedExecutionHandler rejectedExecutionHandler)
ThreadPoolExecutor.AbortPolicypublic void setBeanName(String name)
BeanNameAwareInvoked after population of normal bean properties but before an
 init callback such as InitializingBean.afterPropertiesSet()
 or a custom init-method.
setBeanName in interface BeanNameAwarename - the name of the bean in the factory.
 Note that this name is the actual bean name used in the factory, which may
 differ from the originally specified name: in particular for inner bean
 names, the actual bean name might have been made unique through appending
 "#..." suffixes. Use the BeanFactoryUtils.originalBeanName(String)
 method to extract the original bean name (without suffix), if desired.public void afterPropertiesSet()
initialize() after the container applied all property values.
afterPropertiesSet in interface InitializingBeaninitialize()public void initialize()
createQueue(int)protected edu.emory.mathcs.backport.java.util.concurrent.BlockingQueue createQueue(int queueCapacity)
A LinkedBlockingQueue instance will be created for a positive capacity value; a SynchronousQueue else.
queueCapacity - the specified queue capacity
LinkedBlockingQueue, 
SynchronousQueue
public edu.emory.mathcs.backport.java.util.concurrent.ThreadPoolExecutor getThreadPoolExecutor()
                                                                                        throws IllegalStateException
null)
IllegalStateException - if the ThreadPoolTaskExecutor hasn't been initialized yetpublic void execute(Runnable task)
execute in interface edu.emory.mathcs.backport.java.util.concurrent.Executorexecute in interface TaskExecutortask - the Runnable to execute (never null)Executor.execute(Runnable), 
TaskExecutor.execute(Runnable)public boolean prefersShortLivedTasks()
prefersShortLivedTasks in interface SchedulingTaskExecutortrue if this TaskExecutor prefers
 short-lived taskspublic int getPoolSize()
ThreadPoolExecutor.getPoolSize()public int getActiveCount()
ThreadPoolExecutor.getActiveCount()public void destroy()
shutdown when the BeanFactory destroys
 the task executor instance.
destroy in interface DisposableBeanshutdown()public void shutdown()
ThreadPoolExecutor.shutdown()| 
 | The Spring Framework | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||