近日有消息称:滴滴即将完成一轮额度在50到60亿美元之间的巨额融资,公司估值也将因此突破500亿美元。此轮投资方包括交通银行、招商银行及软银集团等,其中的主要投资方已将投票权委托给滴滴管理层,加强了管理层对公司的绝对控制权。而对于上述消息,滴滴表示“不会对市场传言做评论”。
本篇来自 WizardDragon 的投稿,分享了他对于四大组件启动时一些方法的调用顺序的研究结果,并且深入源码去分析遇到的问题。文章篇幅不短,希望能对大家有所帮助。
WizardDragon 的博客地址:
http://blog.csdn.net/long117long
在做一个项目时,我们想在应用最早启动时,先做一些判断,然后根据判断的结果再决定要不要对其他应用提供服务。
对其他应用提供服务指的是,我们的应用中有 ContentProvider,第三方应用通过 call 方法调用到我们提供的 ContentProvider,ContentProvider 执行逻辑后并给调用的返回结果。当第三方应用调用我们的应用时,我们的应用存在启动和未启动的两种情况。
刚开始,我们将判断逻辑写在了自定义的 Application 的 onCreate 方法中,但等到测试时发现了很多意想不到的情况,比如:
逻辑判断之后的结果是不给第三方应用提供“服务”,但有时候第三方应用能够使用服务,而有时候第三方应用不能使等等的问题。
于是我们跟踪代码,发现了 四大组件 以及 Application 的各个方法( attachBaseContext、onCreate、call 等)启动顺序,跟我们之前理解的稍稍不一样。
在弄清楚了 四大组件 和 Application 在应用冷启动时的执行顺序后,我们才把遇到的问题彻底解决。