Android 启动优化(五)- AnchorTask 1(1)

本文介绍了AnchorTask库在Android开发中的使用,包括如何配置远程依赖,自定义任务类,设置任务执行顺序,监听任务状态以及回调机制。重点展示了如何在主线程和子线程间管理任务,以及如何利用回调函数跟踪任务执行进度。
摘要由CSDN通过智能技术生成

4                .addTask(TASK_NAME_ZERO)

5                .addTask(TASK_NAME_ONE)

6                .addTask(TASK_NAME_TWO)

7                .addTask(TASK_NAME_THREE).afterTask(TASK_NAME_ZERO, TASK_NAME_ONE)

8                .addTask(TASK_NAME_FOUR).afterTask(TASK_NAME_ONE, TASK_NAME_TWO)

9                .addTask(TASK_NAME_FIVE).afterTask(TASK_NAME_THREE, TASK_NAME_FOUR)

10                .build()

11        project.start().await()

1class ApplicationAnchorTaskCreator : IAnchorTaskCreator {

2    override fun createTask(taskName: String): AnchorTask? {

3        when (taskName) {

4            TASK_NAME_ZERO -> {

5                return AnchorTaskZero()

6            }

7

8            TASK_NAME_ONE -> {

9                return AnchorTaskOne()

10            }

11            TASK_NAME_TWO -> {

12                return AnchorTaskTwo()

13            }

14            TASK_NAME_THREE -> {

15                return AnchorTaskThree()

16            }

17            TASK_NAME_FOUR -> {

18                return AnchorTaskFour()

19            }

20            TASK_NAME_FIVE -> {

21                return AnchorTaskFive()

22            }

23        }

24        return null

25    }

26

27}

Demo 跑起来,可以看到预期的效果。

基本使用


第一步:在 moulde build.gradle 配置远程依赖

1implementation ‘com.xj.android:anchortask:1.0.0’

最新的版本号可以看这里 lastedt version

第二步:自定义 AnchorTaskZero,继承 AnchorTask,并指定 taskName,注意 taskName必须是唯一的,因为我们会根据 taskName 找到相应的 AnchorTask 重写相应的方法

1class AnchorTaskZero() : AnchorTask(TASK_NAME_ZERO) {

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}

如果任务 三 依赖任务 二,任务 一,可以这样写

1addTask(TASK_NAME_THREE).afterTask(TASK_NAME_ZERO, TASK_NAME_ONE)

最后,通过 project.start() 方法启动, 如果需要阻塞等待,调用 await() 方法

1AnchorProject.Builder().setContext(context).setLogLevel(LogUtils.LogLevel.DEBUG)

2                .setAnchorTaskCreator(ApplicationAnchorTaskCreator())

3                .addTask(TASK_NAME_ZERO)

4                .addTask(TASK_NAME_ONE)

5                .addTask(TASK_NAME_TWO)

6                .addTask(TASK_NAME_THREE).afterTask(TASK_NAME_ZERO, TASK_NAME_ONE)

7                .addTask(TASK_NAME_FOUR).afterTask(TASK_NAME_ONE, TASK_NAME_TWO)

8                .addTask(TASK_NAME_FIVE).afterTask(TASK_NAME_THREE, TASK_NAME_FOUR)

9                .build()

10project.start().await()

监听任务回调

1project.addListener(object : OnProjectExecuteListener {

2

3            // project 开始执行的时候

4            override fun onProjectStart() {

5                com.xj.anchortask.LogUtils.i(MyApplication.TAG, "onProjectStart ")

6            }

7

8            // project 执行一个 task 完成的时候

9            override fun onTaskFinish(taskName: String) {

10                com.xj.anchortask.LogUtils.i(

11                    MyApplication.TAG,

12                    “onTaskFinish, taskName is $taskName”

13                )

14            }

15

16            // project 执行完成的时候

17            override fun onProjectFinish() {

18                com.xj.anchortask.LogUtils.i(MyApplication.TAG, "onProjectFinish ")

19            }

20

21        })

添加每个任务执行耗时回调

1project.onGetMonitorRecordCallback = object : OnGetMonitorRecordCallback {

2

3            // 所有 task 执行完毕会调用这个方法,Map 存储了 task 的执行时间, key 是 taskName,value 是时间,单位毫秒

4            override fun onGetTaskExecuteRecord(result: Map<String?, Long?>?) {

5                onGetMonitorRecordCallback?.onGetTaskExecuteRecord(result)

6            }

7

8            // 所有 task 执行完毕会调用这个方法,costTime 执行时间

9            override fun onGetProjectExecuteTime(costTime: Long) {

10                onGetMonitorRecordCallback?.onGetProjectExecuteTime(costTime)

11            }

12

13        }

AnchorProject 介绍


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

  2. await 阻塞当前线程,等待所有任务执行完毕之后,会自动往下走,await 方法携带一个参数,timeOutMillion 表示超时等待的时间

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

  4. 添加任务是通过 AnchorProject.Builder().addTask 添加的,典型的构造模式

  5. 设置执行的线程池,可以通过 AnchorProject.Builder().setThreadPoolExecutor(TaskExecutorManager.instance.cpuThreadPoolExecutor)

AnchorTask 介绍


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

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

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

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

  • 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 run()

28

29}

1class AnchorTaskOne : AnchorTask() {

2    override fun isRunOnMainThread(): Boolean {

3        return false

4    }

5
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

总结

其实要轻松掌握很简单,要点就两个:

  1. 找到一套好的视频资料,紧跟大牛梳理好的知识框架进行学习。
  2. 多练。 (视频优势是互动感强,容易集中注意力)

你不需要是天才,也不需要具备强悍的天赋,只要做到这两点,短期内成功的概率是非常高的。

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。

以上就是总结的关于在面试的一些总结,希望对大家能有些帮助,除了这些面试中需要注意的问题,当然最重要的就是刷题了,这里放上我之前整理的一份超全的面试专题PDF

还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

【Android核心高级技术PDF文档,BAT大厂面试真题解析】

这里只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢在关注一下~

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

大家能有些帮助,除了这些面试中需要注意的问题,当然最重要的就是刷题了,这里放上我之前整理的一份超全的面试专题PDF

还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

【Android核心高级技术PDF文档,BAT大厂面试真题解析】

[外链图片转存中…(img-QtgNpKJJ-1713749572148)]

这里只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢在关注一下~

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值