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

郴州网站设计做外墙资料的网站

郴州网站设计,做外墙资料的网站,曲靖网站微信建设,网页布局的基础是几列布局这里系统梳理一下 Android/Kotlin 协程 的一些高级用法。会从 上下文管理、作用域控制、异常处理、性能优化、异步组合 等角度讲解,给你落地可用的示例。1️⃣ 协程作用域(CoroutineScope)与生命周期绑定在 Android 中,协程最好绑…

这里系统梳理一下 Android/Kotlin 协程 的一些高级用法。会从 上下文管理、作用域控制、异常处理、性能优化、异步组合 等角度讲解,给你落地可用的示例。


1️⃣ 协程作用域(CoroutineScope)与生命周期绑定

在 Android 中,协程最好绑定到 生命周期,避免内存泄漏。

Activity/Fragment 中

class MainActivity : AppCompatActivity() {// 生命周期感知协程作用域private val scope = lifecycleScopeoverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)scope.launch {val data = fetchData()updateUI(data)}}
}
  • lifecycleScope:绑定 Activity/Fragment 生命周期,自动取消

  • viewModelScope:绑定 ViewModel 生命周期

手动创建 CoroutineScope

private val customScope = CoroutineScope(Dispatchers.IO + SupervisorJob())
  • 可以用 SupervisorJob() 避免一个子协程失败影响其它子协程

  • 记得在 onDestroy() 或 onCleared() 时 customScope.cancel()


2️⃣ 异步组合:并发和串行

串行执行

val result1 = async { fetchData1() }.await()
val result2 = async { fetchData2() }.await()
val finalResult = combine(result1, result2)
  • 按顺序等待,每个任务完成后再执行下一个

并行执行

val deferred1 = async { fetchData1() }
val deferred2 = async { fetchData2() }
val result1 = deferred1.await()
val result2 = deferred2.await()
  • 并行启动,节省等待时间

并行 + awaitAll

val results = awaitAll(async { fetchData1() },async { fetchData2() },async { fetchData3() }
)

3️⃣ 异常处理与结构化并发

try-catch

scope.launch {try {val result = fetchData()} catch (e: IOException) {handleError(e)}
}

CoroutineExceptionHandler

val handler = CoroutineExceptionHandler { _, exception ->Log.e("Coroutine", "Caught $exception")
}scope.launch(handler) {val result = fetchData()
}

SupervisorJob

  • 父协程失败不影响子协程

val supervisor = SupervisorJob()
val scope = CoroutineScope(Dispatchers.IO + supervisor)

4️⃣ 切换线程/调度器

  • Dispatchers.Main → UI 操作

  • Dispatchers.IO → 网络/文件操作

  • Dispatchers.Default → CPU 密集型计算

scope.launch(Dispatchers.IO) {val data = fetchData()withContext(Dispatchers.Main) {updateUI(data)}
}

use withContext 替代 launch 切换线程

  • 便于返回值,避免嵌套 launch


5️⃣ 超时与取消

超时

try {withTimeout(3000L) {fetchData()}
} catch (e: TimeoutCancellationException) {Log.e("Coroutine", "Timeout")
}

取消

val job = scope.launch {fetchData()
}
job.cancel() // 立即取消

可取消挂起函数

  • 网络、延迟、Channel 等挂起函数是可取消的

  • CPU 密集型循环需要手动检查 isActive

for (i in 1..1000) {if (!isActive) breakdoWork()
}

6️⃣ Channels 与 Flow(响应式数据流)

Channel

  • 类似队列,生产者和消费者解耦

val channel = Channel<Int>()scope.launch {for (i in 1..5) channel.send(i)channel.close()
}scope.launch {for (i in channel) {println(i)}
}

Flow

  • Kotlin 原生的冷流,支持各种操作符

fun fetchNumbers(): Flow<Int> = flow {for (i in 1..5) {delay(100)emit(i)}
}scope.launch {fetchNumbers().map { it * 2 }.filter { it > 5 }.collect { println(it) }
}

7️⃣ 高级技巧

  • 组合多个异步源

val flow1 = flow { emit(fetchData1()) }
val flow2 = flow { emit(fetchData2()) }flow1.combine(flow2) { d1, d2 -> d1 + d2 }.collect { println(it) }
  • 懒启动的 async

val deferred = async(start = CoroutineStart.LAZY) { fetchData() }
deferred.await() // 真正开始执行
  • 异常隔离

    • 使用 SupervisorJob() 避免一个子协程挂掉影响整个父协程

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

相关文章:

  • 【Swift】LeetCode 238.除自身以外数组的乘积
  • GitLab
  • GitHub等平台形成的开源文化正在重塑继任者
  • 【区块链学习笔记】17:以太坊中的GHOST协议
  • 【SpringAI】10.结构化输出
  • 递归经典例题
  • SpringMVC入门:配置、映射与参数处理​
  • 前端笔试复盘 | 知识点总结
  • 春招准备之Java基础篇
  • 有哪几个网站可以做贸易网站备案要多少天
  • 【编程语言】Java基础语法回顾,大学期末考试速通版(选择填空、程序、实践)
  • Redis(85)Redis缓存与Memcached缓存有何区别?
  • 【iOS】自动引用计数(一)
  • 有什么免费的网站wordpress 采集器
  • 网站建设创新成果网站营销如何做
  • 设计模式-享元模式(Flyweight)
  • TMS320C6000 VLIW架构并行编程实战:加速AI边缘计算推理性能
  • 算法学习记录08——并归的应用(LeetCode[315])
  • 【机器人学中的状态估计】3.6.6 习题证明
  • Kafka生产者详解(下):数据去重(幂等性)与数据有序
  • Data Ingestion: Architectural Patterns
  • 网站建设心得体会范文郑州男科医院排行哪家最好
  • 【datawhale秋训营】动手开发RAG系统(应急安全方向) TASK02
  • 怎么搜索整个网站内容网站怎么做成app
  • Python3 集合
  • 九冶建设有限公司官方网站sem优化怎么做
  • MATLAB基于灰靶决策模型的高校信息化设备供应商选择研究
  • java类与对象
  • AI 应用层革命(一)——软件的终结与智能体的崛起
  • Linux Crontab命令详解:轻松设置周期性定时任务