关于阿里热修复sophfix需要冷启动才能生效的探索

30 篇文章 0 订阅

之前公司让我调研关于为什么很多情况下不能即时生效热修复。公司之前用的是阿里的sophfix热修。然后我反编译,通过对比原有包和热修复后的包的差距发现了一些R文件的改动。

最终总结下有两种情况下sophfix必须冷启动后才能完成bugfix。

1 修改涉及内部类的

内部类持有了外部类的引用,修改了外部类的方法,热修复后会使用补丁中的类的方法去替换掉旧的类的方法。但是这些方法所属类就变成补丁包中的类了,此时补丁类中的新方法访问匿名内部类是没有权限的。

原则是不涉及访问权限的变动。

(1)方法中不能包含有内部类

(2)如果直接修改内部类,需要注意是否嵌套了内部类

2 R文件的修改

目前结论 agc这个库会影响即时生效 因为这个sdk反编译的时候发现每次会随机生成一些字符串,改动R文件。然后看了一下改动的前缀都厚agc有关,所以怀疑和这个库有关系,然后把这个库下掉发现确实有关。
后来看了一下agc这个库好像是华为用于apm监控的,不是很清楚之前为啥引用了这个。
image-20210201210747453

支持的即时生效方式示例

(1)修改的方法中不包含内部类

在这里插入图片描述

(2)直接只在内部类中修改

需要注意两点

1.是否嵌套了内部类

2.内部类中是否使用了外部类的私有方法,如图所示将这些方法都注释的时候就能实现即时生效。

image-20210201210252634

注:可以尝试一下看能否用外部类替换掉内部类进行即时生效。

结论

最好和最快的处理方式就是处理code=12的时候,重启app。在红框的地方进行app的重启即可)
在这里插入图片描述

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值