import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
/**
* 线程池
* @author
*/
public class NetThreadPoolUtils {
private NetThreadPoolUtils() {
}
private static int CORE_POOL_SIZE = 5;
private static int MAX_POOL_SIZE = 100;
private static int KEEP_ALIVE_TIME = 10000;
private static BlockingQueue workQueue = new ArrayBlockingQueue(10);
private static ThreadFactory threadFactory = new ThreadFactory() {
private final AtomicInteger integer = new AtomicInteger();
public Thread newThread(Runnable r) {
return new Thread(r, "myThreadPool thread:" + integer.getAndIncrement());
}
};
private static ThreadPoolExecutor threadPool;
static {
threadPool = new ThreadPoolExecutor(CORE_POOL_SIZE, MAX_POOL_SIZE, KEEP_ALIVE_TIME,
TimeUnit.SECONDS, workQueue, threadFactory);
}
public static void execute(Runnable runnable) {
threadPool.execute(runnable);
}
}
本文介绍了一个Java线程池的具体实现方法,包括设置核心线程数、最大线程数、空闲线程存活时间等参数,并使用ArrayBlockingQueue作为任务队列。
1339

被折叠的 条评论
为什么被折叠?



