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

Coroutine(协程)(四)和retrofit搭配使用

如果要用到项目中去,那么必然会涉及到和原来的retrofit共用同一个线程池。Dispatchers.Default里面分为DefaultScheduler和CommonPool。...这个是仿照mainScope来写的 val ioScope = SupervisorJob() + Dispatchers.IO 四、比较与取舍 首先我们要明确,Coroutine本来是准备来取代Rxjava...毕竟Rxjava有两个缺点,第一个学习成本很大,很多人学了两三年也仅仅只是会熟练运用而已(包括我。。。),一旦出了问题,很多时候就是无从下手(从学习成本角度来讲Coroutine简单多了)。...主要区别如下 (1)协程切换完全在用户空间进行,线程切换涉及特权模式切换,需要在内核空间完成; (2)协程切换相比线程切换做的事情更少。 具体可以看 为什么协程切换的代价比线程切换低?...个人觉得,协程更适合于那种不需要开子线程,同时又相当耗时的操作,比如循环遍历,文件操作,频繁的IO操作。

2.7K50

通过Rxjava看Kotlin协程(一)

我在kotlin的协程使用过程中,其实发现了很多rxjava和协程之间很相似的地方。 如果把两个东西孤立起来学习,我觉得成本太高了。...这个地方只是随手写的啊,可能会有bug的 suspendCoroutine 挂起函数 在异步编程中,回调是非常常见的写法,那么如何将回调转换为协程中的挂起函数呢?...这两个函数就是协程给我们提供的将异步回调写成挂起函数的方式。...但是吧,如果现在让我选,我还是觉得协程真香,毕竟链式调用一旦过长的情况下,其实对于开发的能力要求就越高。而kotlin协程的写法起码看起来更像是顺序执行,可读性和可维护性其实对后续来说会更好一点。...预告 下次我应该会写下关于协程的dispatcher和rxjava的Schedulers,我觉得这两个东西也还是很相似的。

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

    通过RxJava看kotlin协程(二)

    协程 Dispatcher 释义 协程上下文(coroutine context)包含一个协程调度器(参阅 CoroutineDispatcher),协程调度器 用于确定执行协程的目标载体,即运行于哪个线程...协程调度器可以将协程的执行操作限制在特定线程上,也可以将其分派到线程池中,或者让它无限制地运行。...接下来我们看下重头戏HandlerContext,这个类就是和rxjava的HandlerScheduler基本一模一样的线程调度器。...结论 如果当你基本了解rxjava的调度器的实现的情况下。大胆点以后面试问你kotlin协程是如何实现调度的逻辑,你就把逻辑copy一遍告诉他就好了。...理解RxJava(三)线程调度原理分析 【译】kotlin 协程官方文档(4)-协程上下文和调度器(Coroutine Context and Dispatchers)

    1K51

    【Kotlin 协程】协程的挂起和恢复 ② ( 协程挂起 和 线程阻塞 对比 )

    文章目录 一、协程挂起 和 线程阻塞 对比 1、协程挂起 2、线程阻塞 3、挂起和阻塞对 UI 的影响 4、挂起分析 一、协程挂起 和 线程阻塞 对比 ---- 挂起是协程中的概念 , 只能在协程中使用...; 阻塞是线程中的概念 , 可以在主线程和子线程中使用 ; 1、协程挂起 协程 挂起 操作 : 在协程中使用 delay 函数 , 挂起 20 秒时间 , 然后 20 秒后更新 UI ; delay...函数是 挂起 suspend 函数 ; // 创建协程 GlobalScope.launch(Dispatchers.Main) { delay(20000) // 主线程更新 UI...UI 的影响 协程 挂起 操作 不会出现 阻塞 UI 刷新的情况 , 挂起的 20 秒不影响 UI 刷新显示 ; 但是如果将主线程阻塞 , UI 不再刷新 , 会出现 ANR 崩溃异常 ; 图形化 GUI..., 会将挂起点的状态保存 , 同时协程停止执行 , 等待挂起函数执行完毕后 , 协程继续执行 ; 相当于阻塞的是协程 , 不会阻塞主线程 ;

    2.3K20

    Kotlin协程-协程派发和调度框架

    一般开发中所接触到的协程类和接口无非是 launch, async, Dispatch.IO...,这些概念是对我们开发者来说的。进入协程源码的世界之后,这些概念就会被一些内部概念所替代。...搞清楚内部概念对分析协程源码来说非常关键。 协程的最小粒度-Coroutine 对没接触过协程的人来说,一个OOP代码的最小调度粒度是函数。...在协程中,最小的调度粒度是协程,在kotlin中叫coroutine。...外部概念和内部概念 协程中外部概念和内部概念的差别很大。对应开发者来说,一个协程的最小粒度coroutine,在协程的内部概念中叫DispatchedContinuation。...这是整个协程调度里最精彩的部分,work-stealing的设计,加上把CPU-bounded和IO-intensive任务区分出来,使得用了协程的代码效率得到极大的提升。

    1.4K30

    有栈协程和无栈协程

    当前很多的编程语言都内置协程特性或者有自己的协程库,如C/C++的libco、golang的goroutine等。而在实现机制上,又可以划分为有栈协程和无栈协程,我们分别进行介绍。...我们选用两个协程库进行介绍,云风的基于ucontext函数簇的协程库和libco。...),并且通过接口coroutine_resume在调度器下面创建了两个协程co1和co2,然后通过调度器循环去拉起其中一个协程,直到一个协程执行完毕。...,当协程阻塞或者退出后,并不指定将执行权限移交给哪个协程,而是统一交还给调度器(主协程),由调度器选择指定的子协程进行调度和拉起。...,每个协程 结构体coroutine,用于描述协程信息,其中: func,一个函数指针,指向 ctx,协程的上下文信息 stack,协程的栈信息,在堆空间上分配出来的 cap/size:栈的容量和当前使用栈空间的大小

    6.6K43

    【Kotlin 协程】协程的挂起和恢复 ① ( 协程的挂起和恢复概念 | 协程的 suspend 挂起函数 )

    文章目录 一、协程的挂起和恢复概念 二、协程的 suspend 挂起函数 一、协程的挂起和恢复概念 ---- 函数 最基本的操作 是 : 调用 call : 通过 函数名或函数地址 调用函数 ; 返回...return : 函数执行完毕后 , 继续执行函数调用的下一行代码 ; 协程 在 调用 call 和 返回 return 基础上 , 又新增了两种 状态 : 挂起 Suspend : 暂停当前执行的协程..., 在子线程中执行异步任务后 , 会马上执行后续的代码 , 只是相当于 普通的多线程操作 ; 协程的作用就是 可以 顺序地执行 异步任务 和 主线程任务 , 其执行顺序按照代码顺序执行 ; 挂起 函数..., 只能在 协程体内部 或者 其它挂起函数 中调用 ; 协程外部不允许使用挂起函数 ; 在协程中 , 执行 挂起 Suspend 函数 , 将 挂起点的信息 记录下来 , 然后执行耗时操作 , 执行完毕后...){} 中 , 可以直接调用挂起函数 ; 挂起 函数 , 只能在 协程体内部 或者 其它挂起函数 中调用 ; 协程外部不允许使用挂起函数 ; 在协程中 , 执行 挂起 Suspend 函数 , 将 挂起点的信息

    2.3K40

    是继续Rxjava还是该试试Kotlin的协程?

    而协程的调用和子程序不同。协程看上去也是子程序,但执行过程中,在子程序内部可中断,然后转而执行别的子程序,在适当的时候再返回来接着执行。...1.2协程和线程的关系 协程和线程,都能用来实现异步调用,但是这两者之间是有本质区别的 (1)协程是编译器级别的,线程是系统级别的。协程的切换是由程序来控制的,线程的切换是由操作系统来控制的。...,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。...关于协程还有一些其他的创建和使用方法,有兴趣的可以去看看官方教程。 3.Rxjava VS 协程 协程相对RxJava有什么优点呢?...(3)协程学习曲线比较平坦,相对于RxJava,协程对初学者更易于学习。

    4K10

    什么是协程?协程和线程的区别

    :1、学习曲线陡峭:响应式编程需要理解异步编程和回调机制,对于初学者来说可能比较困难2、调试复杂:由于异步操作的非顺序执行,调试和错误处理变得更加复杂协程协程基本概念维基百科定义:Coroutines...协程非常适合实现更熟悉的程序组件,如协作任务、异常、事件循环、迭代器、无限列表和管道。简而言之:协程(Goroutines)是一种轻量级的并发编程模型,由编程语言或运行时环境管理,用于执行并发任务。...协程在许多现代编程语言中都有实现,包括 Go、Python、JavaScript(在某种程度上通过异步函数和生成器)等。...("Main: Received", val)}}()wg.Wait() // 等待所有 worker 协程完成}协程和线程的区别协程属于用户级线程,线程属于内核级线程,线程的创建、上下文切换远比协程消耗更大...协程属于非抢占式,不会被其它协程所抢占,而是由开发者自己调度;线程属于抢占式,受到操作系统调度。协程的编码相比与多线程的编码更加复杂,但是协程大多数场景下更适合大并发任务。

    90930

    什么是协程_什么时候使用协程和线程

    先搞清楚,什么是协程。 你可能已经听过『进程』和『线程』这两个概念。 进程就是二进制可执行文件在计算机内存里的一个运行实例,就好比你的.exe文件是个类,进程就是new出来的那个实例。...协程,有几个特点: 协同,因为是由程序员自己写的调度策略,其通过协作而不是抢占来进行切换 在用户态完成创建,切换和销毁 ⚠️ 从编程角度上看,协程的思想本质上就是控制流的主动让出(yield)和恢复(resume...)机制 generator经常用来实现协程 说到这里,你应该明白协程的基本概念了吧?...所以,yield就是yield,下次谁再说yield是协程,我肯定把你xxxx。 PHP协程 前面介绍协程的时候说了,协程需要程序员自己去编写调度机制,下面我们来看这个机制怎么写。...3)协程堆栈 鸟哥文中还有一个协程堆栈的例子。 我们上面说过了,如果在函数中使用了yield,就不能当做函数使用。 所以你在一个协程函数中嵌套另外一个协程函数: <?

    93620

    协程和异步IO

    协程的概念 协程(coroutine)通常又称之为微线程或纤程,它是相互协作的一组子程序(函数)。所谓相互协作指的是在执行函数A时,可以随时中断去执行函数B,然后又中断继续执行函数A。...注意,这一过程并不是函数调用(因为没有调用语句),整个过程看似像多线程,然而协程只有一个线程执行。协程通过yield关键字和 send()操作来转移执行权,协程之间不是调用者与被调用者的关系。...说明:协程适合处理的是I/O密集型任务,处理CPU密集型任务并不是它的长处,如果要提升CPU的利用率可以考虑“多进程+协程”的模式。...Python 3.4:引入asyncio.coroutine装饰器用来标记作为协程的函数,协程函数和asyncio及其事件循环一起使用,来实现异步I/O操作。...Python 3.5:引入了async和await,可以使用async def来定义一个协程函数,这个函数中不能包含任何形式的yield语句,但是可以使用return或await从协程中返回值。

    1K50

    协程和Java实现

    2.线程阻塞状态和可运行状态之间的切换。 3.线程上下文的切换。 协程,英文Coroutines,是一种比线程更加轻量级的存在。正如一个进程可以拥有多个线程一样,一个线程也可以拥有多个协程。...协程,又称微线程,纤程。英文名Coroutine。  最大的优势就是协程极高的执行效率。...因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。...因为协程是一个线程执行,那怎么利用多核CPU呢?最简单的方法是多进程+协程,既充分利用多核,又充分发挥协程的高效率,可获得极高的性能。...Go语言 Go语言对协程的实现非常强大而简洁,可以轻松创建成百上千个协程并发执行。

    2.3K41

    理解协程、LiveData 和 Flow

    也就是 Kotlin 的协程 (Coroutine)。 协程的优势 协程的优点主要来自三个方面: 很容易离开主线程。...如何启动和取消协程 在 Jetpack 组件里,我们为各个组件提供了对应的 scope,比如 ViewModel 就有与之对应的 viewModelScope,如果您想在这个作用域里启动协程,使用如下代码即可...如前所述,我们使用 LiveData 连接 View 和 ViewModel,而在 ViewModel 这里我们则使用刚刚提到的 liveData 协程构造方法来打通 LiveData 和协程,再往右就是调用...这时您可以使用 suspendCancellableCoroutine 协程构造方法,这个方法是协程和回调之间的适配器,会在内部提供一个 continuation 供开发者使用: suspend fun...相信看到这里,您对如何在实际应用中使用协程、LiveData 和 Flow 已经有了比较系统的认识。

    2.6K20

    Go协程-使用和泄漏

    Go协程的基本概念和使用go的协程作为一种更为轻量级的执行单元,与传统的线程相比,goroutine的创建和切换开销很小(这里主要是基于GMP模型,goroutine定义在用户态,只需要P将其队列中的G...:定义一个上下文用来做超时机制context.WithTimeOut,使用无缓冲的chan来作为接受方和发送方的同步接受数据的操作ch:=make(chan result),使用go起一个协程来执行某个函数...即go协程泄漏发生go协程泄漏的情况:当go协程中的发送到无缓冲通道中时,要在接收者接收之前都会进行阻塞,但是当出现超时的情况时,则select则会通过ctx.Done()的方式结束,使得接收器停止接收...search函数返回的result放到ch中然后结束,从而使得该协程的内存以及通道ch的内存被回收掉,避免了协程泄漏2.不完整的工作如下例子中,因为main函数其实在go语言中也是作为一个协程(主协程)...存在的,在main中再起了一个协程,而主函数对应的协程没有等该协程执行完成就结束了。

    39210

    python-高级协程编程-协程的测试和性能优化(一)

    协程是一种高效的异步编程方式,但协程的性能也受到一些因素的影响,如协程的数量、协程的调度等。在实际应用中,我们需要测试协程的性能,并进行优化,以提高应用的吞吐量和响应速度。...一、协程性能测试协程性能测试通常可以分为两个方面:协程数量测试和协程调度测试。协程数量测试是指测试在不同的协程数量下,协程的性能表现;协程调度测试是指测试在不同的协程调度算法下,协程的性能表现。...协程数量测试协程数量测试可以通过编写一个简单的测试程序来实现。以下是一个简单的测试程序,用于测试不同数量的协程在同样的任务下的性能表现。...在run函数中,我们启动了不同数量的do_something协程,并等待它们完成。我们使用asyncio.run函数来运行run函数,并使用time模块来计算运行时间。...我们在for循环中测试了不同数量的协程,从100到1000。在运行测试程序时,我们可以看到每个协程的平均运行时间和协程数量。

    71820
    领券