ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

抽丝剥茧聊Kotlin协程之聊聊Job和SupervisorJob的区别

2021-12-27 10:01:49  阅读:189  来源: 互联网

标签:SupervisorJob 协程 取消 Job 抽丝剥茧 子协程 异常


1. 前言

随着协程的普及,协程知识越来越被面试官青睐。首先,协程的面试题一般都很简洁,一两句简单的话就能把问题描述清楚,其次于面试官而言,协程框架中精妙的数据结构与算法可以很好的考察应聘者对基础知识的掌握程度。相对于烂大街的Android八股文,它又能很好的考察应聘者的主动学习能力。所谓行家一伸手便知有没有。协程知识便是面试场景中的行家和试金石。闲话少叙,本文带大家聊聊Job和SupervisorJob的区别。

2. Job和SupervisorJob的区别

如果你看过协程的官方文档或视频。你应该会知道Job和SupervisorJob的一个区别是,Job的子协程发生异常被取消会同时取消Job的其它子协程,而SupervisorJob不会。

Job启动了3个子协程job1、job2、job3。job1 delay 100毫秒后发生异常,协程被取消了,job2和job3也同样被取消了。

SupervisorJob启动了3个子协程job1、job2、job3。job1 delay 100毫秒后发生异常,协程被取消了,job2和job3并不受影响。

3. 原理

有过面试经历的朋友应该都知道,面试官喜欢问原理。为什么Job和SupervisorJob有这样的区别呢?

源码中寻找答案。Job()返回的是JobImpl对象,SupervisorJob()返回的SupervisorJobImpl对象。而SupervisorJobImpl是JobImpl的子类,并且重写了childCancelled方法,返回值为false。JobImpl继承自JobSupport,它的childCancelled方法源码如下:

Job如何建立父子关系一文,讲解过childCancelled方法。启动协程的Job会和协程本身的Job形成父子关系。当协程被取消时,会调用父Job的childCancelled方法。SupervisorJobImpl直接返回false,表示父Job不会因为子Job被取消而跟随取消。而JobSupport会调用cancelImpl方法,该方法的作用是取消父Job和父Job的所有子Job。

4. 异常处理的区别

恭喜你,前面的问题你都幸运的过关了,正当你暗自庆幸的时候。面试官可能会追问,请问除了子Job的取消不同,还有其它的区别吗?当然有了,比如异常处理机制不一样,Job方式启动的协程如果发生异常,异常会沿着Job树一直往上传递,而SupervisorJob方式启动的协程发生异常,SupervisorJob会将异常交由给协程处理。 这么一说有点抽象,看个例子。

演示协程嵌套,中间有Job类型启动的协程时,如果子协程发生异常,异常会交由根协程处理。

演示协程嵌套,中间有SupervisorJob类型启动的协程时,如果子协程发生异常,异常会交由子协程处理。

回答自此,暗自心想,这下挑不出毛病吧,哪知面试官接着追问,请问原理是什么呢?答案当然要从源码中找寻了。

代码1处,是处理异常的核心逻辑,它首先判断cancelParent的返回值,如果返回false,就调用handleJobException。

cancelParent方法的含义是,当子协程处发生异常,那么它会尝试取消它的父协程,如果返回true表示父协程也被取消,反之表示不能取消父协程,而cancelParent最终也有可能调用代码2处的parent.childCancelled方法。

异常的处理逻辑可以用职场的例子解释。假设职场的潜规则是,任何员工出错了,首要是要向上级报告,如果上级愿意处理你的错误,那员工就不用管了,如果上级将问题打回给员工,那错误就得由员工自己处理

那么回到问题本身,Job就相当于一个好老板,子协程犯的错,它愿意处理,SupervisorJob就相当于一个严厉的老板,子协程自己犯的错,自己解决。

协程异常的处理机制非常复杂,已经超出了本文的范围,我会在我的知识星球,另开一文讲解。

5. 这就够了吗?

行文至此,Job和SupervisorJob搞清楚了。但是还有很多其它的问题,比如:

  1. CancellationException和其它Exception的区别
  2. coroutineScope与SupervisorScope的区别

记得关注"字节小站" 公众号获取更多干货知识~

标签:SupervisorJob,协程,取消,Job,抽丝剥茧,子协程,异常
来源: https://blog.csdn.net/future234/article/details/122165472

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有