上一回,我们通过 CoroutineScope.launch{}
的方式创建了一个协程
这次,我们首先来看另一种协程创建方式:

下面用它来实现上一次程序一样的效果,先来回顾一下上一次程序的代码:

好,下面改用runBlocking的方式:

运行一下:

其它的代码不用多解释,重点是这块:

好,对于咱们已经在用的协程相关的类下面来读一读它们官方的javadoc:

首先先来看一下它,先看下GlobalScope:


开读:







好,继续再来分析一下lauch方法:


其中该方法用到了一个我们还木有学到的关键字:

好,下面正式来读一读它的javadoc:



那下面来看一下CoroutineStart
枚举类的说明


好,再回到launch()的javadoc接下来的继续:

以上就是关于launch函数的javadoc的官方解读,下面再来看一下例子:

我们知道在之前所有编写的示例中都是在这个main方法体中,接下来弄个不一样的写法,看:

这也是之前理论所说:

那这段代码此时它就会阻塞main线程,所以其效果就是main线程需要等runBlocking中的代码执行完了退出,如下:

其效果跟之前的是一模一样的:

在最后抛出一个问题?有木有一种机制能够精确的等待协程执行完了,再执行主线程呢?目前我们的做法不太精确,就是定了一个休眠时间比协程长,如下:

答案肯定是有的,如果是要等某个线程执行完可以用join()【关于线程join()的使用可参考:https://www.cnblogs.com/webor2006/p/7895410.html】,但协程如何等待呢?咱们下次再揭晓。
网友评论