Android Kotlin 协程全面指南

协程是 Kotlin 提供的一套简化异步编程的轻量级线程操作框架,特别适合 Android 开发中的异步任务处理。以下是 Android 开发中需要掌握的协程核心知识点:

1. 协程基础概念

1.1 协程是什么

  • 轻量级线程:比线程更高效,可以在单个线程中运行多个协程

  • 可挂起恢复:可以在不阻塞线程的情况下挂起和恢复执行

  • 结构化并发:提供更好的生命周期管理和错误处理机制

1.2 基本组件

// 启动协程的三种方式
launch { /* 启动不返回结果的协程 */ }
async { /* 启动可返回结果的协程 */ }
runBlocking { /* 阻塞当前线程直到协程完成 */ }

2. 协程构建器

2.1 基本构建器

// 在ViewModel中启动协程
viewModelScope.launch {// 协程体
}// 在Activity/Fragment中启动协程
lifecycleScope.launch {// 自动跟随生命周期取消
}// 全局协程
GlobalScope.launch { // 不推荐在Android中使用,容易内存泄漏
}

2.2 带返回值的构建器

val deferred = viewModelScope.async {delay(1000)"Result"
}// 获取结果
val result = deferred.await()

3. 协程上下文与调度器

3.1 常用调度器

Dispatchers.Main    // 主线程,更新UI
Dispatchers.IO      // IO操作
Dispatchers.Default // CPU密集型计算
Dispatchers.Unconfined // 不指定线程(不推荐)

3.2 上下文组合

viewModelScope.launch(Dispatchers.IO + CoroutineName("MyCoroutine")) {println("Running in ${Thread.currentThread().name}")
}

4. 协程取消与异常处理

4.1 取消协程

val job = viewModelScope.launch {repeat(1000) { i ->ensureActive() // 检查是否被取消delay(500)println("Job: I'm sleeping $i ...")}
}// 取消协程
job.cancel()

4.2 异常处理

viewModelScope.launch {try {val result = withContext(Dispatchers.IO) {fetchData() // 可能抛出异常}} catch (e: Exception) {// 处理异常}
}// 使用SupervisorJob防止异常传播
val scope = CoroutineScope(SupervisorJob())

5. 协程与Android架构组件

5.1 ViewModel集成

class MyViewModel : ViewModel() {fun fetchData() {viewModelScope.launch {try {val data = repository.getData()_uiState.value = UiState.Success(data)} catch (e: Exception) {_uiState.value = UiState.Error(e.message)}}}
}

5.2 Lifecycle集成

class MyActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)lifecycleScope.launch {repeatOnLifecycle(Lifecycle.State.STARTED) {// 只在STARTED状态收集流viewModel.uiState.collect { state ->updateUI(state)}}}}
}

6. 协程与网络请求

6.1 Retrofit集成

interface ApiService {@GET("users/{id}")suspend fun getUser(@Path("id") userId: String): User
}// 使用
viewModelScope.launch {try {val user = apiService.getUser("123")_user.value = user} catch (e: Exception) {_error.value = e.message}
}

6.2 并行请求

viewModelScope.launch {val userDeferred = async { apiService.getUser(userId) }val postsDeferred = async { apiService.getPosts(userId) }val user = userDeferred.await()val posts = postsDeferred.await()_result.value = UserWithPosts(user, posts)
}

7. 协程与Room数据库

7.1 DAO定义

@Dao
interface UserDao {@Insertsuspend fun insert(user: User)@Query("SELECT * FROM users")fun getAllUsers(): Flow<List<User>>
}

7.2 使用示例

viewModelScope.launch {// 插入数据userDao.insert(User(name = "John"))// 观察数据变化userDao.getAllUsers().collect { users ->_users.value = users}
}

8. 协程与Flow

8.1 创建Flow

fun countDownFlow(): Flow<Int> = flow {val countDownFrom = 10for (i in countDownFrom downTo 0) {delay(1000)emit(i)}
}

8.2 收集Flow

viewModelScope.launch {countDownFlow().collect { time ->_countDown.value = time}
}

8.3 Flow操作符

viewModelScope.launch {(1..5).asFlow().filter { it % 2 == 0 }.map { it * it }.collect { println(it) } // 输出 4, 16
}

9. 协程最佳实践

  1. 避免GlobalScope:使用viewModelScope或lifecycleScope

  2. 主线程安全:使用withContext切换调度器

  3. 取消传播:确保协程可以正确取消

  4. 异常处理:为重要操作添加try-catch

  5. 避免阻塞:使用delay而非Thread.sleep

  6. 测试:使用TestCoroutineDispatcher进行单元测试

10. 协程测试

@ExperimentalCoroutinesApi
class MyViewModelTest {@get:Ruleval coroutineRule = MainCoroutineRule()@Testfun `test data loading`() = runTest {val viewModel = MyViewModel(FakeRepository())viewModel.loadData()advanceUntilIdle() // 等待所有协程完成assertEquals(expectedData, viewModel.uiState.value)}
}@ExperimentalCoroutinesApi
class MainCoroutineRule : TestWatcher() {val testDispatcher = StandardTestDispatcher()override fun starting(description: Description) {Dispatchers.setMain(testDispatcher)}override fun finished(description: Description) {Dispatchers.resetMain()}
}

总结

Kotlin协程为Android异步编程提供了强大的解决方案,通过掌握这些核心知识点,您可以:

  • 简化异步代码

  • 避免回调地狱

  • 更好地管理资源

  • 编写更易测试的代码

  • 实现响应式UI更新

在实际开发中,建议结合ViewModel、LiveData/Flow和Retrofit等组件使用协程,构建更健壮的Android应用架构。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/92752.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/92752.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】进程切换与优先级

前言&#xff1a; 上文我们讲到了操作系统与Linux中进程的状态【Linux】进程状态-CSDN博客 本文我们来讲进程的优先级、以及进程的切换 进程优先级 什么是优先级&#xff1f; CPU中资源是有限的&#xff0c;而进程的数量一定是远大于CPU资源的&#xff0c;所以优先级是进程得…

首发即开源!DAWorkBench数据可视化分析软件正式发布!(附源码下载网址)

1 系统介绍DAWorkBench是一款面向科研实验和工程测试场景的数据可视化分析开源软件&#xff0c;支持实现数据清洗、信号处理和交互式可视化等功能。系统集成文件IO、数据处理以及可视化交互三大模块&#xff0c;支持多维数据分析与高质量图表生成&#xff0c;助力用户高效完成从…

Android Studio历史版本快速下载(二次修改记录)

原版&#xff1a;Android Studio历史版本快速下载_android studio 历史版本下载-CSDN博客 一. 最新版本 https://developer.android.com/studio?hlzh-cn 二. 历史版本 中国官网的历史版本为何不能下载&#xff1f;&#xff08;https://developer.android.com/studio/archi…

The Missing Semester of Your CS Education 学习笔记以及一些拓展知识(六)

文章目录The Missing Semester of Your CS Education 学习笔记以及一些拓展知识版本控制Git笔记部分Git的基本工作原理Git 的核心工作原理&#xff1a;快照而非差异Git 的三大工作区域Git的核心对象Git的四个对象对象之间的关系与工作流程&#xff1a;对象的引用Git的安装和基础…

嵌入式与 Linux 系统中的核心图形库全解析

嵌入式与 Linux 系统中的核心图形库全解析 图形库在嵌入式系统与 Linux 桌面系统中扮演着重要角色。从最底层的 GPU 驱动接口&#xff0c;到上层的图形渲染与 GUI 工具包&#xff0c;共同构成了完整的图形显示栈。本文将系统整理图形相关的核心组件&#xff0c;按功能分层分类&…

深度学习模块实践手册(第十二期)

56、Ghost 模块论文《GhostNet: More Features from Cheap Operations》1、作用&#xff1a; Ghost 模块是一种轻量级的特征提取模块&#xff0c;旨在通过廉价操作生成更多特征图&#xff0c;减少计算量的同时保持模型性能。传统卷积神经网络在生成特征图时存在大量冗余计算&am…

自己动手造轮子:如何创建JAR并通过Maven在Spring Boot中引用

让代码复用变得简单优雅——3分钟学会封装专属工具库作为Java开发者&#xff0c;你是否遇到过这些痛点&#xff1f;多个项目重复编写相同工具类工具代码分散难以统一维护团队协作缺乏标准化工具库本文将手把手教你创建自己的JAR包&#xff0c;并优雅地集成到Spring Boot项目中&…

使用dea工具 给vue 里面的ts打断点

在 Vue 项目中使用 TypeScript 时&#xff0c;我们通常会在 IDE&#xff08;如 JetBrains 的 IntelliJ IDEA 或 WebStorm&#xff09;中设置断点进行调试。以下是详细步骤&#xff1a; 准备工作 确保项目已配置 source maps&#xff08;Vue CLI 创建的项目默认已配置&#xff0…

Zabbix 企业级分布式监控

目录 简介 一、监控系统基础 1.1 监控的价值 1.2 监控的 5 大类型与 5 大层次 1.3 监控系统的实现原理 二、Zabbix&#xff1a;企业级监控方案 2.1 Zabbix 简介 2.2 Zabbix 核心功能特性 2.3 Zabbix 角色与架构 三、Zabbix 部署案例 3.1 资源清单 3.2 基础环境配置…

SQL JOIN 全解析:用 `users` 与 `orders` 表彻底掌握内连接、左连接、右连接

SQL JOIN 全解析&#xff1a;用 users 与 orders 表彻底掌握内连接、左连接、右连接 在日常开发中&#xff0c;SQL 的连接&#xff08;JOIN&#xff09;语句是数据库查询的核心技能。尤其在多表联合查询时&#xff0c;不掌握好 INNER JOIN、LEFT JOIN、RIGHT JOIN&#xff0c;…

(一)从零搭建unity3d机械臂仿真-unity3d导入urdf模型

1.新建工程并加载模型 &#xff08;1&#xff09;unity中新建3d工程 &#xff08;2&#xff09;将机器人模型导入到unity3d中 导入开源Unity-Robotics-Hub的机械臂。 详细操作参考视频 ROS Unity URDF Import Testing Robot Motion 使用 URDF Importer工具 在 Unity 中&#x…

Linux之网络部分-应用层自定义协议与序列化

一、应用层 1.1、理解协议 协议是一种 "约定". socket api 的接口, 在读写数据时, 都是按 "字符串" 的方式来发送接收的。如果我们要传输一些 "结构化的数据" 怎么办呢? 其实&#xff0c;协议就是双方约定好的结构化的数据。 1.2、网络版计…

机器学习week3-分类、正则化

1. 逻辑回归1.1. 线性回归 vs 逻辑回归对比维度线性回归逻辑回归任务类型回归&#xff08;预测连续值&#xff09;分类&#xff08;预测离散类别&#xff09;输出范围(−∞,∞)[0,1]&#xff08;概率值&#xff09;损失函数均方误差&#xff08;MSE&#xff09;对数损失&#x…

FastAdmin 中生成插件

在 FastAdmin 中生成一个 OCR 发票识别插件&#xff0c;可以按照以下步骤进行开发。这里假设你已经熟悉 FastAdmin 插件开发的基本流程&#xff0c;并会使用 Composer 和 PHP 扩展。1. 创建插件骨架使用 FastAdmin 命令行工具生成插件基础结构&#xff1a;php think addon -a o…

DevExpress WinForms中文教程:Grouping(分组)- 如何自定义分组算法?

DevExpress WinForms拥有180组件和UI库&#xff0c;能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序&#xff0c;无论是Office风格的界面&#xff0c;还是分析处理大批量的业务数据&#xff0c;它都能轻松胜…

PHP 与 Vue.js 结合的前后端分离架构

PHP 与 Vue.js 结合是构建现代 Web 应用的流行技术栈&#xff0c;通常采用 前后端分离架构。以下是关键要点和推荐实现方案&#xff1a; 一、技术栈组合 角色技术选项后端 (PHP)Laravel (推荐)、Symfony、CodeIgniter前端 (Vue)Vue 2/3、Vue Router、Pinia/Vuex、Vite通信协议…

XML高效处理类 - 专为Office文档XML处理优化

/**** 提供XML读取、写入、修改、查询等高级功能&#xff0c;支持命名空间和复杂XML结构* * 主要功能&#xff1a;* 1. 复杂路径解析&#xff08;支持属性筛选、索引、通配符&#xff09;* 2. 完整节点类型支持&#xff08;元素、文本、CDATA、注释、PI&#xff09;* 3. 高效元…

星慈光编程虫2号小车讲解第一篇--向前向后

星慈光编程虫2号小车是一款基于微控制器&#xff08;如Arduino&#xff09;的编程教学小车&#xff0c;常用于学习机器人控制和编程基础。本讲解将重点介绍小车的基本运动&#xff1a;前进、后退、左转和右转。这些运动通过控制电机实现&#xff0c;通常涉及调整电机的方向和速…

iOS 加固工具有哪些?快速发布团队的实战方案

在当今快速迭代的 iOS 开发环境中&#xff0c;团队需要在高频上线与应用安全之间找到平衡。快速发布不应牺牲安全性&#xff0c;而安全加固也不应成为阻碍上线的瓶颈。这就要求开发者在加固工具的选型与流程设计上&#xff0c;做到既高效又可靠。 那么&#xff0c;iOS 加固工具…

结构型模式-架构解耦与扩展实践

结构型模式聚焦于对象间的组合关系&#xff0c;通过优化类与对象的装配方式&#xff0c;实现系统的灵活性与可扩展性。在分布式系统中&#xff0c;由于多节点协作、跨网络通信及异构环境集成等特性&#xff0c;传统结构型模式需进行适应性改造&#xff0c;以应对分布式特有的复…