协程搬运工-基础(1)
launch不会阻塞所在线程
- 代码
fun main() = runBlocking {
log(“准备启动协程”)// ::A
GlobalScope.launch {
log(“运行协程”)// ::B
delay(1)
}
log(“代码运行到协程体之外”)// ::C
delay(2)
}
- 日志输出
日志: 准备启动协程
日志: 代码运行到协程体之外
日志: 运行协程
- 结论
本例代码中C处的日志比B处先执行,所以证明lunch不会阻塞
async可阻塞也可以不阻塞
不使用await
- 代码
fun main() = runBlocking {
log(“A–进入async方法体内”)//A
val async = GlobalScope.async {
log(“B–开始执行async方法体”)//B
delay(1)
log(“C–async方法体执行完成”)//C
}
log(“D-- async方法体外执行”)//D
delay(2)
}
- 日志
日志: A–进入async方法体内
日志: D-- async方法体外执行
日志: B–开始执行async方法体
日志: C–async方法体执行完成
- 结论
async不会阻塞线程 把上一个例子做一些小改动
使用await
- 代码
fun main() = runBlocking {
log(“A–进入async方法体内”)//A
val async:Deferred = GlobalScope.async {
log(“B–开始执行async方法体”)//B
delay(1)
log(“C–async方法体执行完成”)//C
}
async.await()//加了这样一个调用
log(“D-- async方法体外执行”)//D
delay(2)
}
- 日志
日志: A–进入async方法体内
日志: B–开始执行async方法体
日志: C–async方法体执行完成
日志: D-- async方法体外执行
- 结论
async如果加上了await就会阻塞线程,
runningBlock会阻塞所在线程
- 代码
fun main() {
log(“A–准备进入runningBlock”) //A
runBlocking {
log(“B–进入runningBlock” )//B
delay(1)
log(“C–执行完成runningBLock”)//C
}
log(“D–runBlocking代码块外执行”)//D
runBlocking {
delay(3)
}
}
- 执行结果
日志: A–准备进入runningBlock
日志: B–进入runningBlock
日志: C–执行完成runningBLock
日志: D–runBlocking代码块外执行
- 结论
本示例中runBlocking代码块中的B和C顺序执行完成后才执行的代码块外面的D,这证明了runningBlock会阻塞线程。
suspend函数会阻塞协程
suspend会阻塞所在的协程,不会阻塞线程,因为suspend无法在线程内部调用
- 代码
fun main() = runBlocking {
log(“A–调用suspend函数前”)
wait2Second()
log(“B–调用suspend函数后”)
delay(3)
}
suspend fun wait2Second() {
log(“C–调用suspend函数开始”)
delay(2)
log(“D–调用suspend函数结束”)
}
- 日志
日志: A–调用suspend函数前
日志: C–调用suspend函数开始
日志: D–调用suspend函数结束
日志: B–调用suspend函数后
- 结论
suspend函数会阻塞协程
withContext是否会阻塞协程
- 代码
fun main() = runBlocking {
log(“A–执行withContext前”)
withContext(Dispatchers.Default){
log(“B–开始执行withContext”)
delay(1)
log(“C–withContext执行完成”)
}
log(“D–执行withContext后”)
delay(2)
}
- 日志
日志: A–执行withContext前
日志: B–开始执行withContext
日志: C–withContext执行完成
日志: D–执行withContext后
- 结论
withContext会阻塞协程,withContext只能运行在协程,不能运行在线程中。本例中的Default改为Main就会报错,因为Main相当于运行在主线程
等待一个作业
launch方法会返回一个Job对象,Job对象调用了join方法后,会等待launch协程体执行完成再继续后面的任务。
join方法只能在协程体里面调用,不能在线程中调用
- 代码
fun main() = runBlocking {
log(“A”)
val job = GlobalScope.launch {
log(“B”)
最后
最后为了帮助大家深刻理解Android相关知识点的原理以及面试相关知识,这里放上相关的我搜集整理的24套腾讯、字节跳动、阿里、百度2019-2021BAT 面试真题解析,我把大厂面试中常被问到的技术点整理成了视频和PDF(实际上比预期多花了不少精力),包知识脉络 + 诸多细节。
还有 高级架构技术进阶脑图 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
Android 基础知识点
Java 基础知识点
Android 源码相关分析
常见的一些原理性问题

希望大家在今年一切顺利,进到自己想进的公司,共勉!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
Android 基础知识点
Java 基础知识点
Android 源码相关分析
常见的一些原理性问题
[外链图片转存中…(img-TMSGawT0-1714576195586)]
希望大家在今年一切顺利,进到自己想进的公司,共勉!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
更多推荐


所有评论(0)