之前公司让我调研关于为什么很多情况下不能即时生效热修复。公司之前用的是阿里的sophfix热修。然后我反编译,通过对比原有包和热修复后的包的差距发现了一些R文件的改动。
最终总结下有两种情况下sophfix必须冷启动后才能完成bugfix。
1 修改涉及内部类的
内部类持有了外部类的引用,修改了外部类的方法,热修复后会使用补丁中的类的方法去替换掉旧的类的方法。但是这些方法所属类就变成补丁包中的类了,此时补丁类中的新方法访问匿名内部类是没有权限的。
原则是不涉及访问权限的变动。
(1)方法中不能包含有内部类
(2)如果直接修改内部类,需要注意是否嵌套了内部类
2 R文件的修改
目前结论 agc这个库会影响即时生效 因为这个sdk反编译的时候发现每次会随机生成一些字符串,改动R文件。然后看了一下改动的前缀都厚agc有关,所以怀疑和这个库有关系,然后把这个库下掉发现确实有关。
后来看了一下agc这个库好像是华为用于apm监控的,不是很清楚之前为啥引用了这个。
支持的即时生效方式示例
(1)修改的方法中不包含内部类
(2)直接只在内部类中修改
需要注意两点
1.是否嵌套了内部类
2.内部类中是否使用了外部类的私有方法,如图所示将这些方法都注释的时候就能实现即时生效。
注:可以尝试一下看能否用外部类替换掉内部类进行即时生效。
结论
最好和最快的处理方式就是处理code=12的时候,重启app。在红框的地方进行app的重启即可)