kotlin 中join()方法可以在一个作业中中等待另一个作业结束后再进行其他操作,如下代码对以日志的形式直观化这个效果
import kotlinx.coroutines.*
fun main() = runBlocking{
val job = launch {
try {
repeat(1000){
println("job: I'm sleeping $it 。。。")
delay(500L)
}
}finally {
println("job: I'm running finally")
}
}
delay(1300L)
println("main: I'm tired of waiting!")
job.cancelAndJoin()
// job.cancel()
println("main: Now I can quit")
}
- 当使用job.cancelAndJoin()方法进行取消并join时,日志打印如下:
job: I'm sleeping 0 。。。
job: I'm sleeping 1 。。。
job: I'm sleeping 2 。。。
main: I'm tired of waiting!
job: I'm running finally
main: Now I can quit
可见是job任务会阻塞执行完后才会执行main中的下一行代码
- 注释掉 job.cancelAndJoin(), 打开执行job.cancel()日志如下:
job: I'm sleeping 0 。。。
job: I'm sleeping 1 。。。
job: I'm sleeping 2 。。。
main: I'm tired of waiting!
main: Now I can quit
job: I'm running finally
可见不join的话,main任务不会阻塞等待,会直接往下执行