Android 启动优化(三)- AnchorTask 开源了,你会的还只有初级安卓工程师的技术吗

本文详细介绍了Android的启动优化技术AnchorTask,包括其核心接口IAnchorTask的实现,任务依赖与回调机制,以及如何在主线程中安全地调用和配置任务执行。通过对AnchorTask的掌握,提升你的Android工程能力。
摘要由CSDN通过智能技术生成

1class AnchorTaskC : AnchorTask() {

2

3    override fun getDependsTaskList(): List<Class>? {

4        return ArrayList<Class>().apply {

5            add(AnchorTaskA::class.java)

6            add(AnchorTaskB::class.java)

7        }

8    }

9

10}

最后,通过 AnchorTaskDispatcher.instance .addTask(AnchorTaskFive()) 添加任务,并调用 start() 方法启动, await() 方法表示阻塞等待所有任务执行完毕。

1AnchorTaskDispatcher.instance.setContext(this).setLogLevel(LogUtils.LogLevel.DEBUG).setTimeOutMillion(1000L).

2            .addTask(AnchorTaskZero())

3            .addTask(AnchorTaskOne())

4

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

.addTask(AnchorTaskTwo())

5            .addTask(AnchorTaskThree())

6            .addTask(AnchorTaskFour())

7            .addTask(AnchorTaskFive())

8            .start()

9            .await()

AnchorTaskDispatcher 介绍


  1. AnchorTaskDispatcher start 方法必须在主线程调用,子线程调用会抛出异常。

  2. setTimeOutMillion 方法是配合 await() 方法使用的,单独调用没有任何效果,表示 await 等待的超时时间

  3. await 阻塞当前线程,等待所有任务执行完毕之后,会自动往下走

  4. await() 方法必须在 start 方法之后调用

  5. setThreadPoolExecutor 设置 task 执行的线程池

AnchorTask 介绍


AnchorTask 实现了 IAnchorTask 接口,主要有几个方法

  • isRunOnMainThread(): Boolean 表示是否在主线程运行,默认值是 false

  • priority(): Int 方法 表示线程的优先级别,默认值是 Process.THREAD_PRIORITY_FOREGROUND

  • needWait() 表示当我们调用 AnchorTaskDispatcher await 时,是否需要等待,return true,表示需要等待改任务执行结束,AnchorTaskDispatcher await 方法才能继续往下执行。

  • fun getDependsTaskList(): List<class&gt;?</class 方法返回前置任务依赖,默认值是返回 null.

  • fun run() 方法,表示任务执行的时候

1interface IAnchorTask : IAnchorCallBack {

2

3    /**

4     * 是否在主线程执行

5     */

6    fun isRunOnMainThread(): Boolean

7

8    /**

9     * 任务优先级别

10     */

11    @IntRange(

12        from = Process.THREAD_PRIORITY_FOREGROUND.toLong(),

13        to = Process.THREAD_PRIORITY_LOWEST.toLong()

14    )

15    fun priority(): Int

16

17    /**

18     * 调用 await 方法,是否需要等待改任务执行完成

19     * true 不需要

20     * false 需要

21     */

22    fun needWait(): Boolean

23

24    /**

25     * 当前任务的前置任务,可以用来确定顶点的入度

26     */

27    fun getDependsTaskList(): List<Class>?

28

29    /**

30     * 任务被执行的时候回调

31     */

32    fun run()

33

34}

1class AnchorTaskOne : AnchorTask() {

2    override fun isRunOnMainThread(): Boolean {

3        return false

4    }

5

6    override fun run() {

7        val start = System.currentTimeMillis()

8        try {

9            Thread.sleep(300)

10        } catch (e: Exception) {

11        }

12        LogUtils.i(

13            TAG, "AnchorTaskOne: " + (System.currentTimeMillis() - start)

14        )

15    }

16

17}

监听任务的回调

1val anchorTask = AnchorTaskTwo()

2        anchorTask.addCallback(object : IAnchorCallBack {

3            override fun onAdd() {

4                com.xj.anchortask.LogUtils.i(TAG, “onAdd: $anchorTask”)

5            }

6

7            override fun onRemove() {

8                com.xj.anchortask.LogUtils.i(TAG, “onRemove: $anchorTask”)

9            }

10

11            override fun onStart() {

12                com.xj.anchortask.LogUtils.i(TAG, "onStart:$anchorTask ")

13            }

14

15            override fun onFinish() {

16                com.xj.anchortask.LogUtils.i(TAG, "onFinish:$anchorTask ")

17            }

18

19        })

小结

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值