Android热修复选择哪种,(在线更新apk)

前天在公众号发起了一个HotFix的小调查,结果是 AndFix遥遥领先

更有三个牛逼哄哄的同学自己写!!表示佩服!!


但是我没那么屌,怎么破?只能选择依靠开源


本文记录一个不会自己写HotFix的弱鸡的HotFix调研过程以及最后结果和建议      



现有框架 :

  • AndFix

  • dexposed  

  • Xposed

  • Nuwa

  • HotFix

qq空间的暂时还没开源

AndFix

alibaba出品

功能:method body's replacing 即支持方法级别修复

Support

Android Version :2.3-6.0
dalvik & art runtime

优缺点

无需重启  

andfix只能替换方法而不能增减新的字段,也不能下发类

issue(122个)

查看了一些issue,记录一些可能存在的问题以及缺陷:

  1. 兼容性问题

  2. 部分手机奔溃

  3. 部分手机ANR

  4. 不能改变量的值,不过方法的添加修改,删除,都可以

  5. 需要注意多进程

  6. ART下模式无法对同一个方法进行多次更新

只是说可能,因为很多issue都没人回复

Nuwa

贾吉鑫(原点评)出品

Support

dalvik & art runtime
productFlavor & buildType
proguard & multidex
纯Java 实现

优缺点

基于类级别的修复,不仅仅只是修复方法

需要重启  

issue(46个)

  1. ART环境支持的不好

  2. i50 nuwa只支持 4.0以上,并不是作者所描述的2.3~6.0,作者使用的BaseDexClassLoader这个4.0才有的API,导致4.0以下的手机用Nuwa就必定崩溃,特此提醒

我联系了一下作者,他离开点评去创业后,非常忙碌,所以近期没有时间维护项目,很是可惜,作者的能力十分了得!      

Compare

dexposed 不支持art(5.0+) 比较致命,所以最开始就被排除了

Nuwa HotFix DroidFix 都基于ClassLoader,兼容性以及稳定性好,支持4.0~6.0,对于启动速度有影响,补丁重启后才能生效

AndFix,支持2.3~6.0,但是兼容性以及稳定性较差,关键是不需要重启    

原本想画个表,但是时间有限,不画了,就是这么任性。。。

HotFix Reboot Version LastUpdateTime
AndFix No 0.4.0 2016.4
Nuwa Yes 1.0.0 五个月之前

结果

虽然我原本从各个维度去考虑如何选择,比如Star数,版本号,更新频率,issue解答率等等,
但是到最后其实可选的余地就两个,想要不重启即可生效,就选AndFix,否则可以考虑Nuwa  

另外据小道消息听闻,QQ空间团队的热补(ClassLoader的鼻祖)会在qcan结束后开源,时间未知

我这个只是简单的比较,较为详细的可以看看大帅的『各大热补丁方案分析和比较』一文

另外提供了些许资料,有兴趣的可以阅读原文


最后感谢所有参与调用调表帮助我的同学,以及后台回复我的,seewhy 胡德培 q97531x 同学  


恩, 有机会一起睡觉  

资料

Android热更新实现原理
各大热补丁方案分析和比较
安卓App热补丁动态修复技术介绍

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值