为了查阅日志输出,一般创建线程池我们都需要使用自定义线程工厂,给DEMO
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.atomic.AtomicInteger;
public class NamedThreadFactory implements ThreadFactory {
private static final AtomicInteger poolNumber = new AtomicInteger(1);
private final AtomicInteger threadNumber;
private final ThreadGroup group;
private final String namePrefix;
public NamedThreadFactory(String namePrefix) {
this.threadNumber = new AtomicInteger(1);
SecurityManager s = System.getSecurityManager();
this.group = s != null ? s.getThreadGroup() : Thread.currentThread().getThreadGroup();
this.namePrefix = namePrefix + "-" + poolNumber.getAndIncrement() + "-thread-";
}
@Override
public Thread newThread(Runnable r) {
Thread t = new Thread(this.group, r, this.namePrefix + this.threadNumber.getAndIncrement(), 0L);
t.setDaemon(false);
t.setPriority(5);
return t;
}
}
使用eg
Executors.newScheduledThreadPool(1,new NamedThreadFactory("tt"))
.scheduleAtFixedRate(()->{},100,100,TimeUnit.SECONDS)