线程池(接上篇)

本文通过一个Java示例,展示了如何使用ExecutorService创建固定大小为3的线程池,提交匿名函数任务并观察其并发执行。线程池如何根据任务数量动态调度任务执行,确保资源有效利用。
摘要由CSDN通过智能技术生成

(来自JavaGuide)

一个简单的例子

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

public class ThreadPoolExample {
    public static void main(String[] args) {
        // 创建线程池,使用FixedThreadPool类型,固定大小为3
        ExecutorService executorService = Executors.newFixedThreadPool(3);

        // 提交任务给线程池
        for (int i = 1; i <= 5; i++) {
            int taskNumber = i;
            executorService.execute(() -> {
                System.out.println("Task " + taskNumber + " is being executed by " + Thread.currentThread().getName());
                try {
                    // 模拟任务执行时间
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("Task " + taskNumber + " has completed");
            });
        }

        // 关闭线程池
        executorService.shutdown();
    }
}

在上述代码中,我们创建了一个固定大小为3的线程池(newFixedThreadPool(3))。然后,我们提交了5个任务给线程池进行执行。每个任务都是一个简单的匿名函数(Lambda表达式),它打印任务编号和执行任务的线程名称,并模拟了一个任务的执行时间。

线程池会根据线程的可用性和任务的数量来调度执行。在这个例子中,由于线程池的固定大小为3,所以最多会同时执行3个任务,而剩下的2个任务会在前面的任务完成后执行

输出结果

Task 1 is being executed by pool-1-thread-1
Task 2 is being executed by pool-1-thread-2
Task 3 is being executed by pool-1-thread-3
Task 1 has completed
Task 4 is being executed by pool-1-thread-1
Task 2 has completed
Task 5 is being executed by pool-1-thread-2
Task 3 has completed
Task 4 has completed
Task 5 has completed

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值