协程启动 GlobalScope.launch和runBlocking的区别
协程启动
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在执行时会阻塞主线程,而GlobalScope不会