Java如何判断线程池所有任务是否执行完毕

package csdn;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * @author nineday
 */
public class Test {

    public static void main(String args[]) throws InterruptedException {
        ExecutorService exe = Executors.newFixedThreadPool(50);
        for (int i = 1; i <= 5; i++) {
            exe.execute(new SubThread(i));
        }
        exe.shutdown();
        while (true) {
            if (exe.isTerminated()) {
                System.out.println("结束了!");
                break;
            }
            Thread.sleep(200);
        }
    }
}
上面是主线程的代码,创建了一个能同时执行2个线程的线程池,并投入5个线程,当5个线程都执行完毕后打印---“结束了!”字符串。

exe.shutdown();该方法在加入线程队列的线程执行完之前不会执行。

exe.isTerminated();当shutdown()或者shutdownNow()执行了之后才会执行,并返回true。

在上面的代码中必须有exe.isTerminated()的判断,否则在投入5个线程到线程池后会直接打印:“结束了”。不能达到我们想要的效果。

通过while(true)循环判断exe.isTerminated()的值,为了防止过多的判断浪费资源,可设置线程睡眠Thread.sleep(200);

正是由于这个睡眠,所以当所有线程池中的线程都执行完后,有可能延迟200ms才执行"结束了"语句。这个参数越小延迟越小,结果越准确。

下面是子线程,子线程只是简单的将数字i打印出来;

package csdn;

/**
 * @author nineday
 */
public class SubThread extends Thread{
    
    private final int i;
    public SubThread(int i){
        this.i = i;
    }
    @Override
    public void run(){
        System.out.println(i);
    }
}

执行结果:

run:
3
1
4
5
2
结束了!
成功构建 (总时间: 2 秒)
子线程执行顺序不能控制,所以输出的结果是乱序的。

Java Spring Boot中,创建线程池是一个常见的任务管理机制,它可以帮助我们高效地管理和复用线程资源。Spring Boot提供了`ThreadPoolTaskExecutor`这个工具类来简化线程池的配置和管理。 以下是创建线程池的基本步骤: 1. 配置:首先,在Spring的配置文件`application.properties`或`application.yml`中添加线程池的相关设置,例如线程数、队列大小、线程名称等: ```yaml spring: task: executor: pool-size: 5 # 线程池大小 queue-capacity: 10 # 线程队列容量 thread-name-prefix: "MyTask-" # 线程名称前缀 ``` 2. 创建bean:然后在Spring配置中定义一个`ThreadPoolTaskExecutor` bean,并注入到需要使用的bean中: ```java import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; @Configuration public class ThreadPoolConfig { @Bean(name = "threadPoolTaskExecutor") public ThreadPoolTaskExecutor threadPoolExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); executor.setCorePoolSize(5); executor.setMaxPoolSize(10); // 最大并发数 executor.setQueueCapacity(10); // 定义工作队列大小 executor.setThreadNamePrefix("my-task-executor-"); return executor; } } ``` 3. 使用线程池:现在你可以通过@Autowired注解获取这个线程池实例,并提交Runnable或Callable任务: ```java @Service public class MyService { private final ThreadPoolTaskExecutor executor; @Autowired public MyService(ThreadPoolTaskExecutor executor) { this.executor = executor; } public void executeTask(Runnable task) { executor.execute(task); } // 或者使用Future public Future<?> submitCallable(Callable<?> callable) { return executor.submit(callable); } } ``` 4. 关闭线程池:通常情况下,Spring Boot会在应用退出时自动关闭线程池。但在某些场景下,如果需要手动关闭,可以在适当的地方调用`shutdown()`方法,如`@PreDestroy`方法: ```java @Override @PreDestroy public void destroy() { executor.shutdown(); // 调用此方法停止接收新的任务 try { if (!executor.awaitTermination(60, TimeUnit.SECONDS)) { // 等待60秒让所有任务完成 executor.shutdownNow(); // 强制结束剩余任务 } } catch (InterruptedException e) { executor.shutdownNow(); // 取消中断并立即结束任务 Thread.currentThread().interrupt(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值