协程启动
如果想在协程非作用域中启动协程,有两种方法
runBlocking和GlobalScope.launch{}.start()
其中runBlocking会阻塞主线程,直到回调代码执行完毕,该方法不能用来异步启动,只能用来从非协程作用域切换到协程作用域(比如执行suspend块代码)
使用GlobalScope.launch{}.start(),表示在非协程作用域中启动协程,该方法不会阻塞主线程。
执行下操作就能看出区别
fun main(args: Array<String>) {
println(1)
runBlocking {
println("休眠3秒")
delay(3000)
println(2)
}
println(3)
}
打印顺序:
1
休眠3秒
2
3
---------------------------------------------------
fun main(args: Array<String>) {
println(1)
GlobalScope.launch(Dispatchers.IO) {
println("休眠3秒")
delay(3000)
println(2)
}
println(3)
//阻塞主线程4秒,保证GlobalScope运行期间,JVM不会被关闭
Thread.sleep(4000)
}
打印顺序
1
3
休眠3秒
2
可以看出,runBlocking在执行时会阻塞主线程,直到runBlocking运行结束才执行区域外的代码,而GlobalScope则是两个线程同步执行