Для Oracle есть открытый RFE .Судя по комментариям сотрудника Oracle, они не понимают проблему и не решат ее.Это одна из тех вещей, которые очень просто поддерживать в JDK (без нарушения обратной совместимости), поэтому стыдно, что RFE неправильно поняли.
Как указывалось, вам нужно реализовать свою собственную ThreadFactory .Если вы не хотите использовать Guava или Apache Commons только для этой цели, я приведу здесь ThreadFactory
реализацию, которую вы можете использовать.Это в точности похоже на то, что вы получаете из JDK, за исключением возможности установить префикс имени потока в нечто иное, чем «пул».
package org.demo.concurrency;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.atomic.AtomicInteger;
/**
* ThreadFactory with the ability to set the thread name prefix.
* This class is exactly similar to
* {@link java.util.concurrent.Executors#defaultThreadFactory()}
* from JDK8, except for the thread naming feature.
*
* <p>
* The factory creates threads that have names on the form
* <i>prefix-N-thread-M</i>, where <i>prefix</i>
* is a string provided in the constructor, <i>N</i> is the sequence number of
* this factory, and <i>M</i> is the sequence number of the thread created
* by this factory.
*/
public class ThreadFactoryWithNamePrefix implements ThreadFactory {
// Note: The source code for this class was based entirely on
// Executors.DefaultThreadFactory class from the JDK8 source.
// The only change made is the ability to configure the thread
// name prefix.
private static final AtomicInteger poolNumber = new AtomicInteger(1);
private final ThreadGroup group;
private final AtomicInteger threadNumber = new AtomicInteger(1);
private final String namePrefix;
/**
* Creates a new ThreadFactory where threads are created with a name prefix
* of <code>prefix</code>.
*
* @param prefix Thread name prefix. Never use a value of "pool" as in that
* case you might as well have used
* {@link java.util.concurrent.Executors#defaultThreadFactory()}.
*/
public ThreadFactoryWithNamePrefix(String prefix) {
SecurityManager s = System.getSecurityManager();
group = (s != null) ? s.getThreadGroup()
: Thread.currentThread().getThreadGroup();
namePrefix = prefix + "-"
+ poolNumber.getAndIncrement()
+ "-thread-";
}
@Override
public Thread newThread(Runnable r) {
Thread t = new Thread(group, r,
namePrefix + threadNumber.getAndIncrement(),
0);
if (t.isDaemon()) {
t.setDaemon(false);
}
if (t.getPriority() != Thread.NORM_PRIORITY) {
t.setPriority(Thread.NORM_PRIORITY);
}
return t;
}
}
Когда вы хотите использовать его, вы просто используете преимуществаДело в том, что все Executors
методы позволяют вам предоставить свой ThreadFactory
.
Этот
Executors.newSingleThreadExecutor();
даст ExecutorService, где потоки названы pool-N-thread-M
, но с помощью
Executors.newSingleThreadExecutor(new ThreadFactoryWithNamePrefix("primecalc"));
вы получите ExecutorService, где потоки названы primecalc-N-thread-M
.Voila!