手把手教你在项目中使用线程池,将代码拿上,其中核心代码改为你的就可以
程序员文章站
2022-05-01 13:03:59
...
线程池背景知识
涉及到的是java.util.concurrent包中的ExecutorService。ExecutorService就是Java中对线程池的实现。
Java API对ExecutorService接口的实现有两个,所以这两个即是Java线程池具体实现类
1. ThreadPoolExecutor
2. ScheduledThreadPoolExecutor
创建线程池
创建一个什么样的ExecutorService的实例(即线程池)需要根据具体应用场景而定,不过Java给我们提供了一个Executors工厂类,它可以帮助我们很方便的创建各种类型ExecutorService线程池,Executors一共可以创建下面这四类线程池:
1. newCachedThreadPool 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
2. newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
3. newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
4. newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
备注:Executors只是一个工厂类,它所有的方法返回的都是ThreadPoolExecutor、ScheduledThreadPoolExecutor这两个类的实例。
ExecutorService的使用
ExecutorService executorService = Executors.newFixedThreadPool(10);
executorService.execute(new Runnable() {
public void run() {
将我们代码中要执行的代码放到这个里面就可以了
System.out.println("Asynchronous task");
}
});
executorService.shutdown();
具体例子如下:
List<User> userxx = UserMapper.getUserxx();
//采用ExecutorService提供的java线程池
ExecutorService cacheExecutor = Executors.newFixedThreadPool(100);
if(userxx != null && userxx .size()>0){
for(User duser:userxx ){
cacheExecutor.execute(new Runnable() {
public void run() {
try {
insertXcc(duser);
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
}
cacheExecutor.shutdown();
以上是要往数据库插入很多的信息,所以可以使用线程池,以后使用线程池,可以按照上面的格式改一下就可以了
上一篇: Spring Boot之线程池
下一篇: Spring boot 生成线程池