import java.util.concurrent.Future;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
public class LocalThreadPool {
private static LocalThreadPool mInstance;
private ThreadPoolExecutor threadPool;
private static int MAX_CORE_NUMBER = Runtime.getRuntime().availableProcessors();
private LocalThreadPool() {
threadPool = new ThreadPoolExecutor(MAX_CORE_NUMBER, 10, 60, TimeUnit.SECONDS,
new LinkedBlockingQueue<Runnable>(), new ThreadFactory() {
AtomicInteger auto = new AtomicInteger(0);
@Override
public Thread newThread(Runnable r) {
// TODO Auto-generated method stub
Thread thread = new Thread(r, "crate-thread-" + auto.incrementAndGet());
System.out.println("create thread:" + thread.getName());
return thread;
}
});
threadPool.allowCoreThreadTimeOut(true);
}
public static LocalThreadPool getInstance() {
if (mInstance == null) {
synchronized (LocalThreadPool.class) {
if (mInstance == null) {
mInstance = new LocalThreadPool();
}
}
}
return mInstance;
}
public Future<?> submit(Runnable runnable) {
return threadPool.submit(runnable);
}
public int count() {
return threadPool.getActiveCount();
}
public void destory() {
threadPool.shutdown();
}
}
线程池配置
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。