Java多线程简单了解一下
在你刚了解多线程的时候,你以为的多线程
new Thread(() -> {
// 代码块
});
new Thread(() -> {
// 代码块
});
......
是不是感觉特别low,要一个多线程就要加一个,而且特别无脑,真的就怎么简单吗?按照:能不写的代码就不写的原则!往下看,线程池……
// 创建缓存线程池
ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
for(int i = 0; i < 20; i++) {
final int j = i; // 让内部类能使用i
// 模拟延时
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// 执行任务
cachedThreadPool.execute(() -> {
// 代码内容
System.out.println(Thread.currentThread().getName() + " --> " + j);
});
}
当然这样也不是特别规范,因为容易导致OOM,比较我们都不希望用户OOM,不知道他会在背地里又在骂那个程序员写的代码垃圾了!所以重点来了!!!
// 自定义ExecutorService
ExecutorService threadPool = new ThreadPoolExecutor(2, 5, 1L,TimeUnit.SECONDS,
new LinkedBlockingQueue<>(3),
Executors.defaultThreadFactory(),
new ThreadPoolExecutor.AbortPolicy());
参数介绍:
1.线程池的核心线程数
2.能容纳的最大线程数
3.空闲线程存活时间
4.存活的时间单位
5.存放提交但还未执行任务的队列
6.创建线程的工厂类
7.等待队列满后的拒绝策略
使用线程时,阿里巴巴P3C代码规范插件将提示
手动创建线程池--不允许Executors.newFixedThreadPool创建线程池
最终代码
import com.google.common.util.concurrent.ThreadFactoryBuilder;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.TimeUnit;
// 引入依赖包,创建线程池
private ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("thread-call-runner-%d").build();
private ExecutorService taskExe = new ThreadPoolExecutor(10,20,200L,TimeUnit.MILLISECONDS,new LinkedBlockingQueue<Runnable>(),namedThreadFactory);
在此感谢二位原创的支持
秃头大魔王:Java线程池的正确使用方式——不要再new Thread了
loulanyue_:阿里代码规约:手动创建线程池,效果会更好哦