1abstract class AnchorTask : IAnchorTask {
2
3 private val countDownLatch: CountDownLatch = CountDownLatch(getListSize())
4 private fun getListSize() = getDependsTaskList()?.size ?: 0
5
6 companion object {
7 const val TAG = “AnchorTask”
8 }
9
10 /**
11 * self call,await
12 */
13 fun await() {
14 countDownLatch.await()
15 }
16
17 /**
18 * parent call, countDown
19 */
20 fun countdown() {
21 countDownLatch.countDown()
22 }
23}
排序实现
无环图的拓扑排序,这里采用的是 BFS 算法。具体的可以见 AnchorTaskUtils#getSortResult
方法,它有三个参数
-
list 存储所有的任务
-
taskMap: MutableMap<class, AnchorTask> = HashMap()</class
存储所有的任务,key 是 Class
,value 是 AnchorTask
taskChildMap: MutableMap<class, ArrayList<class>?> =<br /> HashMap()</class</class
,储存当前任务的子任务, key 是当前任务的 class,value 是 AnchorTask 的 list
算法思想
-
首先找出所有入度为 0 的队列,用 queue 变量存储
-
当队列不为空,进行循环判断。
-
从队列 pop 出,添加到结果队列
-
遍历当前任务的子任务,通知他们的入度减一(其实是遍历 taskChildMap),如果入度为 0,添加到队列 queue 里面
-
当结果队列和 list size 不相等试,证明有环
1 @JvmStatic
2 fun getSortResult(
3 list: MutableList, taskMap: MutableMap<Class, AnchorTask>,
4 taskChildMap: MutableMap<Class, ArrayList<Class>?>
5 ): MutableList {
6 val result = ArrayList()
7 // 入度为 0 的队列
8 val queue = ArrayDeque()
9 val taskIntegerHashMap = HashMap<Class, Int>()
10
11 // 建立每个 task 的入度关系
12 list.forEach { anchorTask: AnchorTask ->
13 val clz = anchorTask.javaClass
14 if (taskIntegerHashMap.containsKey(clz)) {
15 throw AnchorTaskException(“anchorTask is repeat, anchorTask is a n c h o r T a s k , l i