> 文章列表 > 协程启动 GlobalScope.launch和runBlocking的区别

协程启动 GlobalScope.launch和runBlocking的区别

协程启动 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不会