文章目录 一、协程取消 二、协程作用域取消 三、协程作用域子协程取消 四、通过抛出异常取消协程 1、Job#cancel 函数 2、默认异常取消协程 3、自定义异常取消协程 一、协程取消 ----...协程取消 : 取消协程作用域 : 取消 协程作用域 会将该作用域中的 所有 子协程 一同取消 ; 取消子协程 : 子协程 的取消 不会影响 同一层级的 兄弟协程的执行 ; 通过抛出异常取消协程 : 协程取消通常会通过...函数 ; 二、协程作用域取消 ---- 创建 协程作用域 CoroutineScope 实例对象 , 传入 调度器 : // 创建协程作用域 val coroutineScope = CoroutineScope...; 然后 , 在协程作用域中 创建两个子协程 ; 最后 , 取消协程作用域 , 同时该作用域内的两个子协程也一并被取消了 ; package kim.hsl.coroutine import android.os.Bundle...:31:51.937 I job1 子协程执行完毕 10:31:51.938 I job0 子协程执行完毕 三、协程作用域子协程取消 ---- 单独取消 协程作用域 中的 子协程 , 协程作用域
文章目录 一、MainScope 协程作用域 二、取消 MainScope 协程作用域 三、Activity 实现 CoroutineScope 协程作用域接口 常见的 CoroutineScope...是一个 函数 , 其返回值类型为 CoroutineScope 协程作用域 ; 这是使用了设计模式中的 工厂模式 , 生产一个 协程作用域 实例对象 ; 之后的 协程操作都要定义在该协程作用域中 ;...是协程任务调度器 , 执行挂起函数 , 系统会自动分配一个 协程任务调度器 ; 二、取消 MainScope 协程作用域 ---- 调用 MainScope 协程作用域 的 cancel 函数 , 即可取...消该 协程作用域 , 同时 该协程作用域内的协程任务不管是否执行完毕 都一并取消 , 该函数是 CoroutineScope 的扩展函数 ; /** * 取消这个范围,包括它的作业和它的所有子任务...启动的协程任务 , 如果取消 mainScope 协程作用域 , 则在该 协程作用域 中执行的 协程任务 , 都会被取消 ; 挂起函数中途被取消 会抛出 JobCancellationException
: 协程任务 运行时 , 必须指定其 CoroutineScope 协程作用域 , 其会 追踪所有的 协程任务 , CoroutineScope 协程作用域 可以 取消 所有由其启动的协程任务 ; 结构化并发...示例 coroutineScope 函数 构建的 协程作用域 代码示例 : 并发执行两个协程 , 取消其中一个协程 , 另外一个协程也会自动取消 ; package kim.hsl.coroutine...函数 构建的 协程作用域 , // 如果有一个 子协程 执行失败 , 则其它 所有的子协程会被取消 ; val job0 = launch...} } } 执行结果 : 在 job1 协程抛出异常后 , 未执行完毕的 job0 协程也被取消 ; 3、supervisorScope 协程作用域构建器 示例 supervisorScope...函数 构建的 协程作用域 代码示例 : 并发执行两个协程 , 取消其中一个协程 , 另外一个协程不会受到影响 , 仍然执行完毕 ; package kim.hsl.coroutine import
文章目录 一、SupervisorJob 协程 二、supervisorScope 协程作用域构建器函数 在上一篇博客介绍了 协程异常处理 【Kotlin 协程】协程异常处理 ① ( 根协程异常处理..., 会将异常 传递给 父协程 , 父协程会执行如下操作 : ① 取消子协程 : 不仅仅取消产生异常的子协程 , 该父协程下所有的子协程都会取消 ; ② 取消父协程 : 将父协程本身取消 ; ③ 向父协程的父协程传播异常...; SupervisorJob 协程实现 : 创建 SupervisorJob 协程 , 需要先 创建一个 协程作用域 , 在 CoroutineScope 构造函数 中 传入 SupervisorJob...协程作用域 调用 launch 构建器函数 , 即可 创建 SupervisorJob 协程 , 这些协程可以自己处理异常 , 不会向父协程传递异常 ; 代码示例 : // 先创建 Supervisor...协程作用域构建器函数 ---- 使用 supervisorScope 作用域构建器函数 , 可以直接创建一个 SupervisorScope 协程作用域 , 在该作用域中定义的 协程 , 都是 SupervisorJob
一、CPU 密集型协程任务取消 ---- 在 协程中 , 定义在 kotlinx.coroutines 包下的 suspend 挂起函数 是可以取消的 ; 但是有一种协程任务 , CPU 密集型协程任务...Log.i(TAG, "退出协程作用域") } } } 执行结果 : 在执行协程任务过程中 , 取消协程 , 但是没有取消成功 , 协程自动执行完毕 ; 18:45:33.896...:23.680 I 退出协程作用域 三、使用 ensureActive 自动处理协程退出 ---- 在协程中 , 可以执行 ensureActive() 函数 , 在该函数中会 自自动判定当前的...:23.680 I 退出协程作用域 四、使用 yield 函数检查协程状态并处理协程取消操作 ---- 在协程中 , 可以使用 yield() 函数 , 检查当前协程的状态 , 如果已经调用 cancel...:59.059 I 退出协程作用域
函数构造超时取消的协程任务 一、释放协程资源 ---- 如果 协程中途取消 , 期间需要 释放协程占有的资源 ; 如果执行的协程任务中 , 需要 执行 关闭文件 , 输入输出流 等操作 , 推荐使用...Log.i(TAG, "取消协程任务") // 取消协程任务 job1.cancelAndJoin() Log.i(TAG, "退出协程作用域...22:06:06.510 I 退出协程作用域 二、使用 use 函数执行 Closeable 对象释放资源操作 ---- 使用 use 函数 可以在 程序结束时 , 执行实现了 Closeable...(TAG, "取消协程任务") // 取消协程任务 job1.cancelAndJoin() Log.i(TAG, "退出协程作用域...23:12:32.093 I 退出协程作用域 四、使用 withTimeoutOrNull 函数构造超时取消的协程任务 ---- 使用 withTimeout 函数 , 可以构造超时取消的协程任务
文章目录 一、调用 Flow#launchIn 函数指定流收集协程 1、指定流收集协程 2、Flow#launchIn 函数原型 3、代码示例 二、通过取消流收集所在的协程取消流 一、调用 Flow..., 开始 收集元素 , 按照顺序逐个处理产生的事件 ( 元素 ) ; 调用 Flow#launchIn 函数 , 传入 协程作用域 作为参数 , 可以 指定 收集 Flow 流元素 的 协程 ; 在上一篇博客...是 协程任务对象 , 可调用 Job#cancel 函数取消该协程任务 ; 2、Flow#launchIn 函数原型 Flow#launchIn 函数原型 : /** * 终端流操作符,在[作用域]中...,提供的作用域负责取消。...collect { println("收集到元素 : $it") } } println("协程作用域取消
文章目录 一、viewModelScope 作用域作用 二、viewModelScope 作用域示例 常见的 CoroutineScope 协程作用域 : GlobalScope : 该作用域是 进程级别的...生命周期函数中取消协程任务 ; viewModelScope : 该作用与仅在 ViewModel 中使用 , 与 ViewModel 生命周期绑定 ; lifecycleScope : 该作用与仅在...Activity 中使用 , 与 Activity 生命周期绑定 ; 一、viewModelScope 作用域作用 ---- viewModelScope 协程作用域 需要绑定 ViewModel 生命周期..., 在特定界面中 , 如可旋转屏幕的 Activity 界面中 , 如果使用 MainScope 协程作用域 , 当屏幕旋转时 , 就会在 onDestory 生命周期函数中 取消协程作用域 , 此时协程相关的临时数据都被取消了...; 当旋转 Activity 界面时 , 会调用当前 Activity 的 onDestory 生命周期函数 , 自然对应的协程作用域也会被取消 , 因此引入 viewModelScope 作用域 ,
不过,我们可以通过直接取消协程启动所涉及的整个作用域 (scope) 来解决这个问题,因为这样可以取消所有已创建的子协程。...// 假设我们已经定义了一个作用域 val job1 = scope.launch { … } val job2 = scope.launch { … } scope.cancel() 取消作用域会取消它的子协程...// 假设我们已经定义了一个作用域 val job1 = scope.launch { … } val job2 = scope.launch { … } // 第一个协程将会被取消,而另一个则不受任何影响...不能在已取消的作用域中再次启动新的协程 如果您使用的是 androidx KTX 库的话,在大部分情况下都不需要创建自己的作用域,所以也就不需要负责取消它们。...例如,当 ViewModel 被清除时,在其作用域内启动的协程也会被一起取消。 为什么协程处理的任务没有停止? 如果我们仅是调用了 cancel 方法,并不意味着协程所处理的任务也会停止。
assert(swoole_last_error() === SWOOLE_ERROR_CO_CANCELED); }); Co::suspend/Co::yield Co::yield 用于手动让出当前协程的执行权
3.LAZY:只有协程被需要时,包括主动调用协程的start、join或await等函数时才会开始调度,如果调度前被取消,那么该协程将直接进入异常结束状态 4.UNDISPATCHED:协程创建后立即在当前函数调用栈中执行...1.runBlocking与coroutineScope runBlocking是常规函数,它会阻塞主线程,而coroutineScope是挂起函数,它们都会等待其协程体和子协助执行结束,作用域构建器使用的是父协程的上下文...二、协程取消 1.协程的取消 1.取消作用域会取消它的子协程,CoroutineScope是创建一个全新的协程上下文,和coroutineScope作用域是不同的,作用域构建器使用的是父协程的上下文 fun...delay(1200) scope } 2.被取消的子协程,不影响其他兄弟协程 fun `test cancel`() = runBlocking { //自定义一个作用域...处于取消中状态的协程不能被挂起,如果想要协程取消后,还能调用挂起函数,我们需要将清理的代码放入NoCancellable CoroutineContext中 这样会挂起运行中的代码,并保持协程的取消中状态
文章目录 一、协程的挂起和恢复概念 二、协程的 suspend 挂起函数 一、协程的挂起和恢复概念 ---- 函数 最基本的操作 是 : 调用 call : 通过 函数名或函数地址 调用函数 ; 返回...return : 函数执行完毕后 , 继续执行函数调用的下一行代码 ; 协程 在 调用 call 和 返回 return 基础上 , 又新增了两种 状态 : 挂起 Suspend : 暂停当前执行的协程..., 在子线程中执行异步任务后 , 会马上执行后续的代码 , 只是相当于 普通的多线程操作 ; 协程的作用就是 可以 顺序地执行 异步任务 和 主线程任务 , 其执行顺序按照代码顺序执行 ; 挂起 函数..., 只能在 协程体内部 或者 其它挂起函数 中调用 ; 协程外部不允许使用挂起函数 ; 在协程中 , 执行 挂起 Suspend 函数 , 将 挂起点的信息 记录下来 , 然后执行耗时操作 , 执行完毕后...){} 中 , 可以直接调用挂起函数 ; 挂起 函数 , 只能在 协程体内部 或者 其它挂起函数 中调用 ; 协程外部不允许使用挂起函数 ; 在协程中 , 执行 挂起 Suspend 函数 , 将 挂起点的信息
如果它的子协程抛出了一个异常,就会导致 UI 作用域 (UI scope) 被取消,并且由于被取消的作用域无法开启新的协程,所有的 UI 组件都会变得无法响应。...它们会创建一个子作用域 (使用一个 Job 或 SupervisorJob 作为父级),可以帮助您根据自己的逻辑组织协程 (例如: 您想要进行一组平行计算,并且希望它们之间互相影响或者相安无事的时候)。...而如果您在扩展中使用 coroutineScope 代替 supervisorScope ,错误就会被传播,而作用域最终也会被取消。 小测验: 谁是我的父级?...△ Child 1 和 Child 2 的父级是 Job 类型,不是 SupervisorJob 这样一来,无论 Child 1 或 Child 2 运行失败,错误都会到达作用域,所有该作用域开启的协程都会被取消...处理异常 协程使用一般的 Kotlin 语法处理异常: try/catch 或内建的工具方法,比如 runCatching (其内部还是使用了 try/catch) 前面讲到,所有未捕获的异常一定会被抛出
本次系列文章 "协程中的取消和异常" 也是 Android 协程相关的内容,我们将与大家深入探讨协程中关于取消操作和异常处理的知识点和技巧。...本篇是另外两篇文章的基础 (第二篇和第三篇将为大家分别详解协程取消操作和异常处理), 所以有必要先讲解一些协程的核心概念,比如 CoroutineScope (协程作用域)、Job (任务) 和 CoroutineContext...CoroutineScope CoroutineScope 会追踪每一个您通过 launch 或者 async 创建的协程 (这两个是 CoroutineScope 的扩展函数)。...当创建 CoroutineScope 的时候,它会将 CoroutineContext 作为构造函数的参数。...现在,大家了解了协程的一些基本概念,在接下来的文章中,我们将在第二篇继续深入探讨协程的取消、第三篇探讨协程的异常处理。
如下是一些在 Go 中通知协程退出的常见方式: 使用通道(Channel):通过发送特定的信号或关闭通道来通知协程退出。这是最简单直接的方法。...**使用 sync.WaitGroup**:虽然 WaitGroup 本身不用于发送取消信号,但它可以用来等待一组协程完成,通常与其他方法(如通道)结合使用来控制协程的退出。 1....在线代码[2] 在上面这两个示例中,当主函数完成其工作后,通过通道发送信号或调用 cancel 函数来通知协程退出。...使用 sync.WaitGroup 控制协程退出 sync.WaitGroup 主要用于等待一组协程的完成。其不直接提供通知协程退出的机制,但可以与其他方法(如通道)结合使用来控制协程的退出。...[7] go协程取消: https://www.google.com/search?
1.前言 作用域是任何一门编程语言中的重中之重,因为它控制着变量与参数的可见性与生命周期。很惭愧,我今天才深入理解JS的作用域..我不配做一个程序员.....开玩笑,什么时候理解都不晚,重要的是理解了以后能不能深深地扎在记忆里,不能,那就写下来 2.块级作用域 在一个代码块(括在一对花括号中的一组语句)中定义的所有变量在代码块的外部是不可见的。...ES6中新增的概念,在ES5中是没有的,ES5中没有? 没有的时候我们代码也写的好好的,现在新增的概念,我不用不行吗? 来,拋一个典型的问题出来,你就明白块级作用域出现的重要性了。...在ES5时代,还没有块级作用域这个概念,但是当时也有一种解决方法,那就是.. .. .. .. .....,是可以修改内部属性的,数组同理; 5.总结 主要总结一下块级作用域、以及块级作用域出现的意义,方便更好的记住。
而如果您想要将协程限定在其他作用域,请继续阅读,接下来本文将对此进行讨论。...我们想要此操作的运行时长超过 viewModelScope,这个目的要如何达成呢? 我们需要在 Application 类中创建自己的作用域,并在由它启动的协程中调用这些操作。...当协程所需的生存期比调用处作用域的生存期更长时,我们可以使用 applicationScope 来运行协程。...❌ ✅ 使用 NonCancellable 正如您在本系列第二篇文章 协程中的取消和异常 | 取消操作详解 中看到的,您可以使用 withContext(NonCancellable) 在被取消的协程中调用挂起函数...每当您需要执行一些超出当前作用域范围的工作时,我们都建议您在您自己的 Application 类中创建一个自定义作用域,并在此作用域中执行协程。
coroutineScope 是继承外部 Job 的上下文创建作用域,在其内部的取消操作是双向传播的,子协程未捕获的异常也会向上传递给父协程。...原来协程 ③ 抛出了未捕获的异常,进入了异常完成的状态,它与父协程 ② 之间遵循默认的作用域规则,因此 ③ 会通知它的父协程也就是 ② 取消,② 根据作用域规则通知父协程 ① 也就是整个作用域取消,这是一个自下而上的一次传播...差别主要在于 9 与 10、11与12的区别,如果把 scope 换成 supervisorScope,我们发现 ③ 的异常并没有影响作用域以及作用域内的其他子协程的执行,也就是我们所说的“自作自受”。...这一块儿稍微显得有点儿复杂,但仔细理一下主要有三条线: 协程内部异常处理流程:launch 会在内部出现未捕获的异常时尝试触发对父协程的取消,能否取消要看作用域的定义,如果取消成功,那么异常传递给父协程...异常在作用域内的传播:当协程出现异常时,会根据当前作用域触发异常传递,GlobalScope 会创建一个独立的作用域,所谓“自成一派”,而 在 coroutineScope 当中协程异常会触发父协程的取消
协程作用域所有协程都必须在一个协程作用域CoroutineScope内运行。一个 CoroutineScope 管理一个或多个相关的协程。协程如何开启呢?...可以通过launch和async函数**创建协程并将其函数主体的执行分派给相应的调度程序**。调度程序也就是launch和async的函数主体会运行在哪个线程中。...如何看阻塞同一协程体内的代码是阻塞的,但是协程体里面又开启了一个协程,两个协程不影响各自运行,但父协程取消的时候默认子协程也会取消。...上面是针对某一个具体的协程取消,如果我想全部取消呢?比如界面销毁的时候,通过调用协程域的取消,位于这个协程域里面的协程都会取消。...CoroutineDispatcher:将工作分派到适当的线程。CoroutineName:协程的名称,可用于调试。CoroutineExceptionHandler:处理未捕获的异常。
协程作用域 所有协程都必须在一个协程作用域CoroutineScope内运行。一个 CoroutineScope 管理一个或多个相关的协程。 协程如何开启呢?...可以通过launch和async函数创建协程并将其函数主体的执行分派给相应的调度程序。 调度程序也就是launch和async的函数主体会运行在哪个线程中。...如何看阻塞 同一协程体内的代码是阻塞的,但是协程体里面又开启了一个协程,两个协程不影响各自运行,但父协程取消的时候默认子协程也会取消。...上面是针对某一个具体的协程取消,如果我想全部取消呢?比如界面销毁的时候,通过调用协程域的取消,位于这个协程域里面的协程都会取消。...CoroutineDispatcher:将工作分派到适当的线程。 CoroutineName:协程的名称,可用于调试。 CoroutineExceptionHandler:处理未捕获的异常。
领取专属 10元无门槛券
手把手带您无忧上云