简化Java多线程编程的实用利器!

ThreadUtil通过封装Java标准库中的ExecutorServiceCountDownLatch等并发工具,提供了一系列简洁易用的方法。

    1. 异步执行任务(excuteAsync)
  1. ThreadUtil(excuteAsync)
  2. 方法允许开发者以异步方式执行任务,避免阻塞主线程。
    • • 示例代码:
  • • 该方法返回一个Future对象,可以通过调用get()方法获取任务结果。
    1. 在公共线程池中执行任务(execute)
    • ThreadUtil.execute()方法直接在公共线程池中执行任务,无需手动创建线程池。
    • • 示例代码:
  • • 这种方式适合需要频繁执行小任务的场景。
    1. 创建新的线程池(newExecutor)
  1. ThreadUtil.newExecutor()
  2. 方法允许开发者创建自定义的线程池,并设置核心线程数和最大线程数。
  • • 通过这种方式,可以更好地控制线程资源的分配。
    1. 等待一组线程完成(newCountDownLatch)
  1. ThreadUtil.newCountDownLatch(int count)
  2. 方法创建一个
  3. CountDownLatch
  4. 对象,用于等待一组线程完成。
  • • 这种方式适用于需要同步多个子任务的场景。
    1. 挂起当前线程(sleep)
  1. ThreadUtil.sleep(long time)
  2. 方法封装了
  3. Thread.sleep()
  4. ,可以安全地挂起当前线程。
  • • 该方法避免了因未正确处理中断信号而导致的异常。
    1. 获取当前线程信息( currentThread)
  1. ThreadUtil.currentThread()
  2. 方法返回当前线程的实例。
  • • 该方法便于开发者获取当前线程的信息并进行调试。
    1. 结束线程(interrupt)
  1. ThreadUtil.interrupt(Thread thread)
  2. 方法可以安全地中断指定的线程。
  • • 该方法确保了中断信号的正确处理。
    1. 获取线程堆栈信息(getStack trace)
  1. ThreadUtil.getStack trace(Thread thread)
  2. 方法返回指定线程的堆栈信息。
  • • 该方法便于开发者分析线程运行时的状态。

我们通过一个简单的业务场景来演示其使用方法。订单处理需要调用多个异步服务,并在所有服务完成后返回结果。

代码实现

ini 复制代码
import cn.hutool.core.util.ThreadUtil;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CountDownLatch;

publicclassOrderProcessor {
    publicstaticvoidmain(String[] args)throws InterruptedException {
        // 创建一个CountDownLatch对象,用于等待所有子任务完成
        CountDownLatchlatch=newCountDownLatch(3);

        // 异步调用三个服务
        CompletableFuture<Void> future1 = ThreadUtil(excuteAsync(() -> {
            System.out.println("服务1开始执行");
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("服务1执行完成");
            latch.countDown();
        }));

        CompletableFuture<Void> future2 = ThreadUtil(excuteAsync(() -> {
            System.out.println("服务2开始执行");
            try {
                Thread.sleep(1500);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("服务2执行完成");
            latch.countDown();
        }));

        CompletableFuture<Void> future3 = ThreadUtil(excuteAsync(() -> {
            System.out.println("服务3开始执行");
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("服务3执行完成");
            latch.countDown();
        }));

        // 等待所有服务完成
        latch.await();

        System.out.println("所有服务已完成,开始汇总结果");
    }
}

运行结果:

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、转发、在看。

关注公众号:woniuxgg,在公众号中回复:笔记 就可以获得蜗牛为你精心准备的java实战语雀笔记,回复面试、开发手册、有超赞的粉丝福利!

相关推荐
devlei6 小时前
从源码泄露看AI Agent未来:深度对比Claude Code原生实现与OpenClaw开源方案
android·前端·后端
努力的小郑8 小时前
Canal 不难,难的是用好:从接入到治理
后端·mysql·性能优化
Victor3569 小时前
MongoDB(87)如何使用GridFS?
后端
Victor3569 小时前
MongoDB(88)如何进行数据迁移?
后端
小红的布丁9 小时前
单线程 Redis 的高性能之道
redis·后端
GetcharZp9 小时前
Go 语言只能写后端?这款 2D 游戏引擎刷新你的认知!
后端
宁瑶琴10 小时前
COBOL语言的云计算
开发语言·后端·golang
普通网友11 小时前
阿里云国际版服务器,真的是学生党的性价比之选吗?
后端·python·阿里云·flask·云计算
IT_陈寒11 小时前
Vue的这个响应式问题,坑了我整整两小时
前端·人工智能·后端
Soofjan12 小时前
Go 内存回收-GC 源码1-触发与阶段
后端