上一回,我们通过 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】,但协程如何等待呢?咱们下次再揭晓。
网友评论