App启动优化-基于有向无环图的sdk初始化方案,android面试题大全

本文介绍了如何利用有向无环图(DAG)优化Android应用启动时的SDK初始化过程,通过多线程遍历图以减少启动时间。在介绍中,展示了遍历图的算法细节,以及在不同机型上的性能对比,说明了优化的有效性。文章还提及在实际项目中应用此方法可提升初始化速度30%-40%,并分享了作者的行业经验与学习资源。
摘要由CSDN通过智能技术生成

// 如果下一节点的入度是0,将入度为 0 的节点入栈,用于下一次遍历

if (nextNode.inDegree == 0) {

nodeStack.push(nextNode);

}

}

}

}

// 抛出异常中断程序异常信息中提示 存在环的相关 Task

if (taskCount != topologicalSort.size()) {

taskNodes.removeAll(topologicalSort);

StringBuilder builder = new StringBuilder();

builder.append(" [");

for (TaskNode taskNode : taskNodes) {

builder.append(taskNode.getClass().getSimpleName());

builder.append(“,”);

}

builder.append(" ]");

throw new RuntimeException(“there is a ring among” + builder.toString());

}

}

拓补排序排序过程

上图是一个有向无环图,输出的拖布排序序列为[1,2,4,3,5],如果 3,5 是循环依赖关系,则排序只会输出[1,2,4]就结束了。图中的元素无法全部遍历完成。

2.3 多线程遍历图

因为牵扯子线程初始化任务,必须确保在跳转第一个业务页面时,所有的Task都初始化完成了。也就是说从遍历开始到结束,主线程是不可以跳转到闪屏页面的,而且部分初始化会在主线程进行。阻塞主线程就成了必需要做的事。

多线程遍历

runTask(root); // 开始遍历

waitMain();

private void runTask(final TaskNode taskNode) {

// 只有入度为0的节点才能开始运

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值