当前位置: 首页 > news >正文

Android,Java,Kotlin 确保线程顺序执行的多种实现方式

在多线程编程中,有时需要确保一个线程必须等待另一个线程执行完毕后再执行。本文将介绍几种常见的方法来实现这一需求,并提供详细的代码示例。

1. 使用 Thread.join()
Thread.join() 是最简单直接的方法,它会让当前线程等待目标线程执行完毕。

代码示例:

Thread thread1 = new Thread(() -> {
    System.out.println("线程1执行");
});

Thread thread2 = new Thread(() -> {
    try {
        thread1.join(); // 等待线程1执行完毕
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    System.out.println("线程2执行");
});

thread1.start();
thread2.start();

2. 使用 CountDownLatch
CountDownLatch 是一个同步工具,可以让线程等待其他线程完成。通过 countDown() 和 await() 方法实现线程间的同步。

代码示例:

CountDownLatch latch = new CountDownLatch(1);

Thread thread1 = new Thread(() -> {
    System.out.println("线程1执行");
    latch.countDown(); // 通知线程2可以执行
});

Thread thread2 = new Thread(() -> {
    try {
        latch.await(); // 等待线程1执行完毕
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    System.out.println("线程2执行");
});

thread1.start();
thread2.start();

3. 使用 ExecutorService 和单线程池
通过 Executors.newSingleThreadExecutor() 创建单线程池,任务会按提交顺序执行,确保线程2在线程1之后执行。

代码示例:

ExecutorService executor = Executors.newSingleThreadExecutor();

executor.submit(() -> {
    System.out.println("线程1执行");
});

executor.submit(() -> {
    System.out.println("线程2执行");
});

executor.shutdown(); // 关闭线程池

4. 使用 CompletableFuture
CompletableFuture 是 Java 8 引入的异步编程工具,可以方便地实现任务依赖。

代码示例:

CompletableFuture.runAsync(() -> {
    System.out.println("线程1执行");
}).thenRun(() -> {
    System.out.println("线程2执行");
}).join(); // 等待所有任务完成

5. 使用 HandlerThread
HandlerThread 是 Android 中带有 Looper 的线程,可以按顺序处理任务。

代码示例:

HandlerThread handlerThread = new HandlerThread("MyHandlerThread");
handlerThread.start();

Handler handler = new Handler(handlerThread.getLooper());

handler.post(() -> {
    System.out.println("线程1执行");
});

handler.post(() -> {
    System.out.println("线程2执行");
});

6. 使用 BlockingQueue
BlockingQueue 是一个线程安全的队列,可以用来实现任务的有序执行。

代码示例:

BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>();

Thread thread1 = new Thread(() -> {
    System.out.println("线程1执行");
    queue.offer(() -> System.out.println("线程2执行")); // 将任务2放入队列
});

Thread thread2 = new Thread(() -> {
    try {
        Runnable task = queue.take(); // 等待任务2
        task.run();
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
});

thread1.start();
thread2.start();

7. 使用 Kotlin 协程
如果使用 Kotlin,协程是最简洁的方式,可以轻松实现线程间的依赖关系。

代码示例:

import kotlinx.coroutines.*

fun main() = runBlocking {
    launch {
        println("线程1执行")
    }.join() // 等待线程1执行完毕

    launch {
        println("线程2执行")
    }
}

以下是几种常见方法的对比:

方法 适用场景 优点 缺点
Thread.join() 简单场景 代码简单 不适合复杂场景

CountDownLatch 需要明确同步点的场景 灵活性强 需要额外管理计数器

单线程池 任务队列场景 代码简洁 需要手动关闭线程池

CompletableFuture Java 8+ 的异步编程 现代化,功能强大 需要 Java 8+ 支持

HandlerThread Android 环境 适合 Android 开发 仅适用于 Android

BlockingQueue 需要任务队列的场景 线程安全,灵活 代码稍复杂

Kotlin 协程 Kotlin 项目 代码简洁,现代化 仅适用于 Kotlin

根据具体需求选择最适合的方案。如果只是简单的线程等待,推荐使用 Thread.join() 或 CountDownLatch;如果是 Android 开发,推荐使用 HandlerThread 或 Kotlin 协程。

http://www.dtcms.com/a/69197.html

相关文章:

  • Java EE Web环境安装
  • 反射机制的理解
  • 遥感数据获取、处理、分析到模型搭建全流程学习!DeepSeek、Python、OpenCV驱动空天地遥感数据分析
  • 有关Spring 简介和第一个Spring案例:基于XML配置的IoC容器
  • windows10 清理 C 盘
  • AutoGen-构建问答智能体
  • C#程序员接口调用工具与方法
  • Unity进阶课程【二】Mask 组件的使用 UI遮罩效果以及透明抠图效果
  • Linux 部署 Spring Boot 项目, Web项目(2025版)
  • SpringCloud
  • Java8计算集合属性的最小值
  • 基于javaweb的SpringBoot杂物商城系统设计与实现(源码+文档+部署讲解)
  • 正则表达式入门及常用的正则表达式
  • SpringCloudAlibaba项目搭建
  • 数据库原理9
  • Tcp网络通信的基本流程梳理
  • docker指令整理
  • SpaceClaim二次开发(4)
  • MATLAB风光柴储微网粒子群算法
  • 上海高考解析几何
  • 『大模型笔记』什么是MCP?将AI智能体与数据库和API集成
  • 向量库集成指南
  • Windows下安装Git客户端
  • 关于在vue3中使用keep-live+component标签组合,实现对指定某些组件进行缓存或不缓存的问题
  • 【论文笔记】Contrastive Learning for Compact Single Image Dehazing(AECR-Net)
  • 一窥DeepSeek开源EPLB项目:揭开技术背后的面纱
  • 西门子S7-1200 PLC远程上下载程序方案
  • 在1688平台上如何实现铺货和上传商品的自动化?
  • PinnDE:基于物理信息神经网络的微分方程求解库
  • 如何在PHP中实现数据加密与解密:保护敏感信息