Application, Activity, ContentProvider启动顺序

文章探讨了在Android系统中,Application、Activity和ContentProvider的启动顺序,通过分析调用栈和源码,揭示了在 Dex 加壳过程中ContentProvider能正常运行的原理。作者发现,ContentProvider的初始化在Application的初始化过程中发生,而Activity则在其之后。关键在于DexClassLoader的替换,使得加壳后的类能够被正确加载和初始化。
摘要由CSDN通过智能技术生成

先交代一下本次问题的背景,由于最近在调研dex加壳,按照Jack_jia的加壳技术方案中的步骤做了demo,然后在android5.0以上系统上运行的时候发现,在解壳的过程中设置ContentProvider的地方有点问题,然后我就把那段代码注释掉了,结果发现程序竟然能够正常运行,感觉很奇怪,由于本人资历尚浅,对Android和加壳的机制都是一知半解,特别是对于ContentProvider更是完全不了解,所以决定把这部分搞清楚。

就先在Application,Activity和ContentProvider三个类的onCreate函数中打印了log,发现它们的启动顺序为:

Application->attachBaseContext =====>ContentProvider->onCreate =====>Application->onCreate =====>Activity->onCreate


如果是这个顺序就更奇怪了,因为在被加壳dex中定义的Provider这时候竟然已经被启动了,在脱壳程序中ProxyApplication->attachBaseContext只是创建了被加壳dex的DexClassLoader,并LoadedApk中的classloader替换掉

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值