Class BasicThreadFactory
- java.lang.Object
-
- org.apache.commons.lang3.concurrent.BasicThreadFactory
-
- All Implemented Interfaces:
java.util.concurrent.ThreadFactory
public class BasicThreadFactory extends java.lang.Object implements java.util.concurrent.ThreadFactory
An implementation of the
ThreadFactory
interface that provides some configuration options for the threads it creates.A
ThreadFactory
is used for instance by anExecutorService
to create the threads it uses for executing tasks. In many cases users do not have to care about aThreadFactory
because the default one used by anExecutorService
will do. However, if there are special requirements for the threads, a customThreadFactory
has to be created.This class provides some frequently needed configuration options for the threads it creates. These are the following:
- A name pattern for the threads created by this factory can be specified.
This is often useful if an application uses multiple executor services for
different purposes. If the names of the threads used by these services have
meaningful names, log output or exception traces can be much easier to read.
Naming patterns are format strings as used by the
String.format()
method. The string can contain the place holder%d
which will be replaced by the number of the current thread (ThreadFactoryImpl
keeps a counter of the threads it has already created). For instance, the naming pattern"My %d. worker thread"
will result in thread names like"My 1. worker thread"
,"My 2. worker thread"
and so on. - A flag whether the threads created by this factory should be daemon threads. This can impact the exit behavior of the current Java application because the JVM shuts down if there are only daemon threads running.
- The priority of the thread. Here an integer value can be provided. The
java.lang.Thread
class defines constants for valid ranges of priority values. - The
UncaughtExceptionHandler
for the thread. This handler is called if an uncaught exception occurs within the thread.
BasicThreadFactory
wraps another thread factory which actually creates new threads. The configuration options are set on the threads created by the wrapped thread factory. On construction time the factory to be wrapped can be specified. If none is provided, a defaultThreadFactory
is used.Instances of
BasicThreadFactory
are not created directly, but the nestedBuilder
class is used for this purpose. Using the builder only the configuration options an application is interested in need to be set. The following example shows how aBasicThreadFactory
is created and installed in anExecutorService
:// Create a factory that produces daemon threads with a naming pattern and // a priority BasicThreadFactory factory = new BasicThreadFactory.Builder() .namingPattern("workerthread-%d") .daemon(true) .priority(Thread.MAX_PRIORITY) .build(); // Create an executor service for single-threaded execution ExecutorService exec = Executors.newSingleThreadExecutor(factory);
- Since:
- 3.0
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
BasicThreadFactory.Builder
A builder class for creating instances ofBasicThreadFactory
.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.Boolean
getDaemonFlag()
Returns the daemon flag.java.lang.String
getNamingPattern()
Returns the naming pattern for naming newly created threads.java.lang.Integer
getPriority()
Returns the priority of the threads created by this factory.long
getThreadCount()
Returns the number of threads this factory has already created.java.lang.Thread.UncaughtExceptionHandler
getUncaughtExceptionHandler()
Returns theUncaughtExceptionHandler
for the threads created by this factory.java.util.concurrent.ThreadFactory
getWrappedFactory()
Returns the wrappedThreadFactory
.java.lang.Thread
newThread(java.lang.Runnable runnable)
Creates a new thread.
-
-
-
Method Detail
-
getWrappedFactory
public final java.util.concurrent.ThreadFactory getWrappedFactory()
Returns the wrappedThreadFactory
. This factory is used for actually creating threads. This method never returns null. If noThreadFactory
was passed when this object was created, a default thread factory is returned.- Returns:
- the wrapped
ThreadFactory
-
getNamingPattern
public final java.lang.String getNamingPattern()
Returns the naming pattern for naming newly created threads. Result can be null if no naming pattern was provided.- Returns:
- the naming pattern
-
getDaemonFlag
public final java.lang.Boolean getDaemonFlag()
Returns the daemon flag. This flag determines whether newly created threads should be daemon threads. If true, this factory object callssetDaemon(true)
on the newly created threads. Result can be null if no daemon flag was provided at creation time.- Returns:
- the daemon flag
-
getPriority
public final java.lang.Integer getPriority()
Returns the priority of the threads created by this factory. Result can be null if no priority was specified.- Returns:
- the priority for newly created threads
-
getUncaughtExceptionHandler
public final java.lang.Thread.UncaughtExceptionHandler getUncaughtExceptionHandler()
Returns theUncaughtExceptionHandler
for the threads created by this factory. Result can be null if no handler was provided.- Returns:
- the
UncaughtExceptionHandler
-
getThreadCount
public long getThreadCount()
Returns the number of threads this factory has already created. This class maintains an internal counter that is incremented each time thenewThread(Runnable)
method is invoked.- Returns:
- the number of threads created by this factory
-
newThread
public java.lang.Thread newThread(java.lang.Runnable runnable)
Creates a new thread. This implementation delegates to the wrapped factory for creating the thread. Then, on the newly created thread the corresponding configuration options are set.- Specified by:
newThread
in interfacejava.util.concurrent.ThreadFactory
- Parameters:
runnable
- theRunnable
to be executed by the new thread- Returns:
- the newly created thread
-
-