Kotlin协程到底是怎么切换线程的?你是否知晓?,最新高频Android笔试题分享

本文深入探讨了Kotlin协程中的线程切换,对比了GlobalScope与ViewModelScope的区别,揭示了调度器在协程中的作用。通过源码分析,阐述了协程如何通过调度器和拦截器实现线程的切换,并重点讲解了Dispatcher的实现,如HandlerDispatcher如何将任务切换到主线程。此外,文章还提到了delay函数在协程中的线程切换行为。
摘要由CSDN通过智能技术生成

public val coroutineContext: CoroutineContext

}

可以看出CoroutineScope的代码很简单,主要作用是提供CoroutineContext,协程运行的上下文

我们常见的实现有GlobalScope,LifecycleScope,ViewModelScope

1.2 GlobalScopeViewModelScope有什么区别?

public object GlobalScope : CoroutineScope {

/**

  • 返回 [EmptyCoroutineContext].

*/

override val coroutineContext: CoroutineContext

get() = EmptyCoroutineContext

}

public val ViewModel.viewModelScope: CoroutineScope

get() {

val scope: CoroutineScope? = this.getTag(JOB_KEY)

if (scope != null) {

return scope

}

return setTagIfAbsent(

JOB_KEY,

CloseableCoroutineScope(SupervisorJob() + Dispatchers.Main.immediate)

)

}

两者的代码都挺简单,从上面可以看出

1.GlobalScope返回的为CoroutineContext的空实现

2.ViewModelScope则往CoroutineContext中添加了JobDispatcher

我们先来看一段简单的代码

fun testOne(){

GlobalScope.launch {

print(“1:” + Thread.currentThread().name)

delay(1000)

print(“2:” + Thread.currentThread().name)

}

}

//打印结果为:DefaultDispatcher-worker-1

fun testTwo(){

viewModelScope.launch {

print(“1:” + Thread.currentThread().name)

delay(1000)

print(“2:” + Thread.currentThread().name)

}

}

//打印结果为: main

上面两种Scope启动协程后,打印当前线程名是不同的,一个是线程池中的一个线程,一个则是主线程

这是因为ViewModelScopeCoroutineContext中添加了Dispatchers.Main.immediate的原因

我们可以得出结论:协程就是通过Dispatchers调度器来控制线程切换的

1.3 什么是调度器?

从使用上来讲,调度器就是我们使用的Dispatchers.Main,Dispatchers.DefaultDispatcher.IO

从作用上来讲,调度器的作用是控制协程运行的线程

从结构上来讲,Dispatchers的父类是ContinuationInterceptor,然后再继承于CoroutineContext

它们的类结构关系如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值