parent
8ce987ffb0
commit
f5bfb8bd9e
@ -1,61 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright 2020 OPSLI 快速开发平台 https://www.opsli.com
|
|
||||||
* <p>
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
||||||
* use this file except in compliance with the License. You may obtain a copy of
|
|
||||||
* the License at
|
|
||||||
* <p>
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
* <p>
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
* License for the specific language governing permissions and limitations under
|
|
||||||
* the License.
|
|
||||||
*/
|
|
||||||
package org.opsli.common.thread.factory;
|
|
||||||
|
|
||||||
import java.util.concurrent.ThreadFactory;
|
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Created Date by 2019/12/26 0026.
|
|
||||||
* 自定义线程池工厂
|
|
||||||
* @author Parker
|
|
||||||
*/
|
|
||||||
public class NameableThreadFactory implements ThreadFactory{
|
|
||||||
|
|
||||||
private final AtomicInteger poolNumber = new AtomicInteger(1);
|
|
||||||
|
|
||||||
private final ThreadGroup threadGroup;
|
|
||||||
|
|
||||||
private final AtomicInteger threadNumber = new AtomicInteger(1);
|
|
||||||
|
|
||||||
public final String namePrefix;
|
|
||||||
|
|
||||||
public NameableThreadFactory(String name){
|
|
||||||
SecurityManager s = System.getSecurityManager();
|
|
||||||
threadGroup = (s != null) ? s.getThreadGroup() :
|
|
||||||
Thread.currentThread().getThreadGroup();
|
|
||||||
if (null==name || "".equals(name.trim())){
|
|
||||||
name = "pool";
|
|
||||||
}
|
|
||||||
namePrefix = name +"-"+
|
|
||||||
poolNumber.getAndIncrement() +
|
|
||||||
"-thread-";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Thread newThread(Runnable r) {
|
|
||||||
Thread t = new Thread(threadGroup, r,
|
|
||||||
namePrefix + threadNumber.getAndIncrement(),
|
|
||||||
0);
|
|
||||||
if (t.isDaemon()){
|
|
||||||
t.setDaemon(false);
|
|
||||||
}
|
|
||||||
if (t.getPriority() != Thread.NORM_PRIORITY){
|
|
||||||
t.setPriority(Thread.NORM_PRIORITY);
|
|
||||||
}
|
|
||||||
return t;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in new issue