首页
学习
活动
专区
圈层
工具
发布

【Kotlin 协程】协程底层实现 ③ ( 结构化并发 | MainScope 作用域 | 取消协程作用域 | Activity 实现 CoroutineScope 协程作用域接口 )

文章目录 一、MainScope 协程作用域 二、取消 MainScope 协程作用域 三、Activity 实现 CoroutineScope 协程作用域接口 常见的 CoroutineScope...是一个 函数 , 其返回值类型为 CoroutineScope 协程作用域 ; 这是使用了设计模式中的 工厂模式 , 生产一个 协程作用域 实例对象 ; 之后的 协程操作都要定义在该协程作用域中 ;...是 协程作用域的扩展函数 , 其后的代码块参数就是 协程作用域 , 在其中执行协程任务 ; public fun CoroutineScope.launch( context: CoroutineContext...消该 协程作用域 , 同时 该协程作用域内的协程任务不管是否执行完毕 都一并取消 , 该函数是 CoroutineScope 的扩展函数 ; /** * 取消这个范围,包括它的作业和它的所有子任务...启动的协程任务 , 如果取消 mainScope 协程作用域 , 则在该 协程作用域 中执行的 协程任务 , 都会被取消 ; 挂起函数中途被取消 会抛出 JobCancellationException

1.5K11

【Kotlin 协程】协程异常处理 ② ( SupervisorJob 协程 | supervisorScope 协程作用域构建器函数 )

| 自动传播异常 | 在协程体捕获异常 | 向用户暴露异常 | 在 await 处捕获异常 | 非根协程异常处理 | 异常传播特性 ) , 其中介绍了 协程中异常的传播特性 : 协程 运行时 , 产生异常...: 继续将异常传播给 父协程的父协程 ; 这样就会导致 某个子协程一旦出现异常 , 则 兄弟协程 , 父协程 , 父协程的兄弟协程 , 父协程的父协程 等等 都会被取消 , 这样牵连太大 , 因此本篇博客中引入几种异常处理机制解决上述问题...; SupervisorJob 协程实现 : 创建 SupervisorJob 协程 , 需要先 创建一个 协程作用域 , 在 CoroutineScope 构造函数 中 传入 SupervisorJob...作用域 // 在该作用域下创建的协程都是 SupervisorJob 协程 val supervisorScope = CoroutineScope(SupervisorJob()) // 通过 Supervisor...协程作用域构建器函数 ---- 使用 supervisorScope 作用域构建器函数 , 可以直接创建一个 SupervisorScope 协程作用域 , 在该作用域中定义的 协程 , 都是 SupervisorJob

94110
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Kotlin 协程】协程取消 ① ( 协程作用域取消 | 协程作用域子协程取消 | 通过抛出异常取消协程 | Job#cancel 函数 | 自定义异常取消协程 )

    文章目录 一、协程取消 二、协程作用域取消 三、协程作用域子协程取消 四、通过抛出异常取消协程 1、Job#cancel 函数 2、默认异常取消协程 3、自定义异常取消协程 一、协程取消 ----...协程取消 : 取消协程作用域 : 取消 协程作用域 会将该作用域中的 所有 子协程 一同取消 ; 取消子协程 : 子协程 的取消 不会影响 同一层级的 兄弟协程的执行 ; 通过抛出异常取消协程 : 协程取消通常会通过...; 然后 , 在协程作用域中 创建两个子协程 ; 最后 , 取消协程作用域 , 同时该作用域内的两个子协程也一并被取消了 ; package kim.hsl.coroutine import android.os.Bundle...协程作用域之后 , 该作用域下的 job0 和 job1 子协程都被取消了 , 两个子协程都没有执行完毕 ; 10:33:33.468 I job0 子协程执行开始 10:33:33.471 I...:31:51.937 I job1 子协程执行完毕 10:31:51.938 I job0 子协程执行完毕 三、协程作用域子协程取消 ---- 单独取消 协程作用域 中的 子协程 , 协程作用域

    1.3K20

    【Kotlin 协程】协程启动 ⑤ ( 协程作用域构建器 | runBlocking 函数 | coroutineScope 函数 | supervisorScope 函数 )

    实现 CoroutineScope 协程作用域接口 ) 【Kotlin 协程】协程底层实现 ④ ( 结构化并发 | viewModelScope 作用域示例 ) 博客中介绍了 结构化并发 ; 结构化并发的作用...: 协程任务 运行时 , 必须指定其 CoroutineScope 协程作用域 , 其会 追踪所有的 协程任务 , CoroutineScope 协程作用域 可以 取消 所有由其启动的协程任务 ; 结构化并发...CoroutineScope.() -> R): R 共同点 : 这两个 协程作用域构建器 构建的协程 都会等待 协程体 中的所有 协程任务 和 子协程 执行完毕 ; 代码示例 : 在下面的代码中 ,...supervisorScope 函数 ) ---- 1、协程作用域构建器概念 coroutineScope 函数 构建的 协程作用域 , 如果有一个 子协程 执行失败 , 则其它 所有的子协程会被取消..., 未执行完毕的 job0 协程也被取消 ; 3、supervisorScope 协程作用域构建器 示例 supervisorScope 函数 构建的 协程作用域 代码示例 : 并发执行两个协程

    64830

    【Kotlin 协程】协程底层实现 ④ ( 结构化并发 | viewModelScope 作用域示例 )

    文章目录 一、viewModelScope 作用域作用 二、viewModelScope 作用域示例 常见的 CoroutineScope 协程作用域 : GlobalScope : 该作用域是 进程级别的..., 与应用进程同级 , 即使 Activity 被销毁 , 协程任务也可以继续执行 ; MainScope : 该 作用域仅在 Activty 中 , 如果 Activity 被销毁 , 则 在 onDestory...Activity 中使用 , 与 Activity 生命周期绑定 ; 一、viewModelScope 作用域作用 ---- viewModelScope 协程作用域 需要绑定 ViewModel 生命周期..., 在特定界面中 , 如可旋转屏幕的 Activity 界面中 , 如果使用 MainScope 协程作用域 , 当屏幕旋转时 , 就会在 onDestory 生命周期函数中 取消协程作用域 , 此时协程相关的临时数据都被取消了...; 当旋转 Activity 界面时 , 会调用当前 Activity 的 onDestory 生命周期函数 , 自然对应的协程作用域也会被取消 , 因此引入 viewModelScope 作用域 ,

    1.1K20

    协程及Python中的协程

    1 协程 1.1协程的概念 协程,又称微线程,纤程。英文名Coroutine。一句话说明什么是线程:协程是一种用户态的轻量级线程。...我们把一个线程中的一个个函数叫做子程序,那么子程序在执行过程中可以中断去执行别的子程序;别的子程序也可以中断回来继续执行之前的子程序,这就是协程。...(2)进行阻塞(Blocking)操作(如IO时)会阻塞掉整个程序 2 Python中如何实现协程 2.1 yield实现协程   前文所述“子程序(函数)在执行过程中可以中断去执行别的子程序;别的子程序也可以中断回来继续执行之前的子程序...2.2 greenlet实现协程   Python的 greenlet就相当于手动切换,去执行别的子程序,在“别的子程序”中又主动切换回来。。。 greenlet协程例子: 1 #!...gr1.switch() 2.3  gevent 实现协程   Gevent 是一个第三方库,可以轻松通过gevent实现协程程,在gevent中用到的主要模式是Greenlet, 它是以C扩展模块形式接入

    1.5K20

    Java 中的协程库 - Quasar

    这就是协程适用的场景。...协程,其实就是在一个线程中,有一个总调度器,对于多个任务,同时只有一个任务在执行,但是一旦该任务进入阻塞状态,就将该任务设置为挂起,运行其他任务,在运行完或者挂起其他任务的时候,再检查待运行或者挂起的任务的状态...协程的方式更多用来做阻塞密集型(比如 I/O)的操作,计算密集型的还是使用线程更加合理。 Java 官方并没有协程库。但是伟大的社区提供了一个优秀的库,它就是 Quasar。...那么我们为什么称 Quasar 为协程库呢?...这里 Quasar 就是通过抛异常(SuspendExecution)的方式来达到的,这样就完成了以线程的方式实现协程。

    3K31

    java协程框架quasar和kotlin中的协程

    接下来要分享的这个开源项目,正是解决了在java中只能使用多线程模型开发高并发应用的窘境,使得java也能像Go语言那样使用协程的语义开发了。...而反观协程,基于固定的几个线程调度,可以轻松实现百万级的协程处理,而且内存稳稳的。 后记 最后,博主以为Quasar只是一个框架层面的东西,所以就又去看了下同样是jvm语言的kotlin的协程。...,有种震惊的赶脚,kotlin的同步模型牛逼呀,瞬时感觉到发现了java里的骚操作了,可以使用kotlin的协程来代替java中的多线程操作。...io操作,io操作是阻塞的,协程的并发也就变成了调度协程的几个线程的并发了。...那为什么上面的测试结果差距这么大呢,是因为我错误的把协程实现里的阻塞等同于线程的阻塞。

    81330

    Golang中的协程(goroutine)

    进程         进程就是程序在操作系统中的一次执行过程,是系统进行资源分配和调度的基本单位,进程是一个动态概念,是程序在执行过程中分配和管理资源的基本单位,每一个进程都有一个自己的地址空间。...一个进程可以创建多个线程,同一个进程中的多个线程可以并发执行,一个程序要运行的话至少有一个进程。...并行可以显著提高程序的性能,特别是在多核 CPU 中,能够利用多个 CPU 核心进行计算。...Go 语言中的协程是由 Go 运行时调度器(scheduler)进行管理和调度的。当程序启动时,Go 运行时会默认启动一个主协程,主协程会创建其他的子协程,这些协程会被分配到不同的系统线程上进行执行。...} 多协程和多线程         Golang中每个goroutine(协程)默认占用内存比Java、C的线程少。

    77940

    Gevent超好用的协程库

    而实际开发中我们经常有高并发的需求,这就要求我们的代码在跑的更快的同时需要单位时间内执行更多的有效逻辑、减少无用的等待。 什么是协程?...我们可以认为线程是轻量级的进程,所以你也可以理解协程是轻量级的线程。协程即在一个线程执行 A 函数时可以随时中断去执行 B 函数,可以自由切换。...其中 gevent 是 Python 协程的一个经典实现。 什么是 gevent?...,gevent 无法捕捉,导致代码是串行的,虽然我们创建了协程,但是并没有起到异步的作用。...Tip 在 HTTP 的异步开发中,猴子补丁要在导入 gevent 之前打,否则会出现异常。 以上就是今天的全部内容了,感谢您的阅读,我们下节再会。

    64030

    JavaScript中的作用域和作用域链

    作用域(Scope) 1. 作用域 作用域是在运行时代码中的某些特定部分中变量,函数和对象的可访问性。换句话说,作用域决定了代码区块中变量和其他资源的可见性。...全局作用域 在代码中任何地方都能访问到的对象拥有全局作用域,一般来说以下几种情形拥有全局作用域: 最外层函数和在最外层函数外面定义的变量拥有全局作用域 var outVariable = "我是最外层变量...// 张三写的代码中 var data = {a: 100} // 李四写的代码中 var data = {x: true} 这就是为何 jQuery、Zepto 等库的源码,所有的代码都会放在(function...因为放在里面的所有变量,都不会被外泄和暴露,不会污染到外面,不会对其他的库或者 JS 脚本造成影响。这是函数作用域的一个体现。...你基本上可以用 let 来代替 var 进行变量声明,但会将变量的作用域限制在当前代码块中。块级作用域有以下几个特点: 1.声明变量不会提升到代码块顶部。

    2.7K10

    Rust中的作用域及作用域的规则

    下图展示了一个字符是如何存储在内存中的:变量 s 保存在栈中,其值是一个指向堆的地址,堆中则保存了字符串的具体内容。 所有权的实际规则 Rust 中每个值都绑定有一个变量,称为该值的所有者。...每个值只有一个所有者,而且每个值都有它的作用域。 一旦当这个值离开作用域,这个值占用的内存将被回收。 fn main() { let value1 = 1; println!...("{}", s4); } // 所有权转移给了s3,此时该值的作用域也变成了s3的作用域,所以离开了s4的作用域该值还能访问 println!...在绝大多数情况下,生命周期和变量的作用域是一致的: fn main() { let i = 3; // i 的生命周期开始 { let borrow1 = &i; //...但问题来了,字符串的内容 “Hello World!” 的作用域是函数体,而函数却试图返回它的引用。

    4.3K30

    协程中的“协”字是什么意思?

    Golang中的协程(coroutine)概念,其名字来源可以从两个方面来解释,一是历史背景,二是技术特性。 历史背景 协程(coroutine)这个概念最早可以追溯到计算机科学的早期。...在Golang中,协程被实现为“goroutine”,它是Go语言并发设计的核心。Goroutine在使用和概念上与传统的协程有所不同,但基本思想是相通的。...“协”是否可以代表为用户态调度是协作式的 在协程(coroutine)的上下文中,“协”是可以理解为协作式的(cooperative),特别是在强调与用户态调度相对应的场景中。...这意味着一个运行中的协程会一直执行,直到它显式地表示要让出执行权(例如,通过等待I/O操作、显式挂起或调用其他协程等方式)。...这种设计使得goroutine能够高效地利用多核处理器,同时保持使用上的简单性。 因此,“协”在协程中确实可以理解为强调了协作式的调度方式,这是区别于传统线程抢占式调度的一个重要特点。

    29000

    探索 PHP 中的协程实现

    当协程已暂停且尚未完成时,它将保持当前状态。 暂停和恢复 协程执行后,它将开始执行其任务。在执行过程中,协程可以暂停自身,将控制权移交给代码的其余部分。这意味着执行的暂停只能源自协程内部 。...由于协程是可以暂停和恢复的函数,因此协程内部的值在协程尚未完成时保持可用。当协程重新获得控制权并继续执行时,它仍然可以引用这些变量。只有当协程完成时,其内部变量才会从内存中释放。...使用 Generator 的协程 PHP 中首次引入协程是在 5.5 版中以 Generator 的形式出现的。 现在,大多数开发人员都知道 Generator 是保留内存的迭代器。...即将到来:协程实践 现在我们已经探索了什么是协程以及 PHP 如何通过 Generators 和 Fibers 支持它们,下一步是让它们发挥作用。...在下一篇文章中,我们将深入探讨 PHP 中的并发性,探索 Revolt 等事件循环、协程调度器和 ReactPHP 等异步库。我们将了解协程如何适应构建响应式、非阻塞 PHP 应用程序的更大图景。

    11110

    揭秘kotlin协程中的CoroutineContext

    ,协程才能会启动和执行 Thread.sleep(1000) } 上面首先构造了一个CoroutineScope,它是协程的作用域,用于控制协程的生命周期,构造CoroutineScope需要一个...,接下来我先简单讲解一下组成CoroutineContext的各个Element的作用,CoroutineContext主要由以下4个Element组成: Job:协程的唯一标识,用来控制协程的生命周期...的一个子接口)的complete方法都会让当前协程进入完成中(Completing)状态, 处于完成中状态的协程会等所有子协程都完成后才进入完成(Completed)状态。...,不同的是DefaultScheduler内部依赖的是kotlin自己实现的线程池逻辑,而CommonPool内部依赖的是java类库中的Executor,默认情况下useCoroutinesScheduler...中的最后一个元素, ContinuationInterceptor它也是继承自Element,通常叫做协程上下文拦截器,它的主要作用是在协程执行前拦截它,从而在协程执行前做出一些其他的操作,前面我们讲到

    2.1K31

    js中的作用域

    前言 相信自从es6出来之后,你一定多少知道或者已经在项目中实践了部分的块级作用域,在函数或者类的内部命名变量已经在使用let了,但是你知道它真正的作用是什么吗?...又是因为什么我们要用这个块级作用域,本文与你一起探讨块级作用域的场景以及所有细节问题。...,利用了函数的链接作用域的特点,同时可以对外暴露部分,将我们需要的部分保留在内存中。...块级作用域 场景一 循环中的块级作用域 如果我们有一个遍历循环的绑定事件,并且需要把当前的指针绑定到对应方法中。...,利用let块级作用域特性,区别就是定义变量时 i是块级变量,所以定义的函数中的变量也是当时的块级作用域,不随外面非块级元素值变化影响 var arr=[] for(let i=0;i<10;i++)

    3.8K20
    领券