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 介绍
-
AnchorTaskDispatcher start
方法必须在主线程调用,子线程调用会抛出异常。 -
await
阻塞当前线程,等待所有任务执行完毕之后,会自动往下走,await 方法携带一个参数,timeOutMillion 表示超时等待的时间 -
await()
方法必须在 start 方法之后调用 -
添加任务是通过
AnchorProject.Builder().addTask
添加的,典型的构造模式 -
设置执行的线程池,可以通过
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移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
总结
其实要轻松掌握很简单,要点就两个:
- 找到一套好的视频资料,紧跟大牛梳理好的知识框架进行学习。
- 多练。 (视频优势是互动感强,容易集中注意力)
你不需要是天才,也不需要具备强悍的天赋,只要做到这两点,短期内成功的概率是非常高的。
对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。
以上就是总结的关于在面试的一些总结,希望对大家能有些帮助,除了这些面试中需要注意的问题,当然最重要的就是刷题了,这里放上我之前整理的一份超全的面试专题PDF
还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
【Android核心高级技术PDF文档,BAT大厂面试真题解析】
这里只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢在关注一下~
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
大家能有些帮助,除了这些面试中需要注意的问题,当然最重要的就是刷题了,这里放上我之前整理的一份超全的面试专题PDF
还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
【Android核心高级技术PDF文档,BAT大厂面试真题解析】
[外链图片转存中…(img-QtgNpKJJ-1713749572148)]
这里只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢在关注一下~
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!