Tinker是什么
Tinker是微信官方的Android热补丁解决方案,它支持动态下发代码、So库以及资源,让应用能够在不需要重新安装的情况下实现更新。当然,你也可以使用Tinker来更新你的插件。
它主要包括以下几个部分:
1.gradle编译插件: tinker-patch-gradle-plugin
2.核心sdk库: tinker-android-lib
3.非gradle编译用户的命令行版本: tinker-patch-cli.jar
为什么使用Tinker`
当前市面的热补丁方案有很多,其中比较出名的有阿里的AndFix、美团的Robust以及QZone的超级补丁方案。但它们都存在无法解决的问题,这也是正是我们推出Tinker的原因。
总的来说:
AndFix作为native解决方案,首先面临的是稳定性与兼容性问题,更重要的是它无法实现类替换,它是需要大量额外的开发成本的;
Robust兼容性与成功率较高,但是它与AndFix一样,无法新增变量与类只能用做的bugFix方案;
Qzone方案可以做到发布产品功能,但是它主要问题是插桩带来Dalvik的性能问题,以及为了解决Art下内存地址问题而导致补丁包急速增大的。
特别是在Android N之后,由于混合编译的inline策略修改,对于市面上的各种方案都不太容易解决。而Tinker热补丁方案不仅支持类、So以及资源的替换,它还是2.X-7.X的全平台支持。利用Tinker我们不仅可以用做bugfix,甚至可以替代功能的发布。Tinker已运行在微信的数亿Android设备上,那么为什么你不使用Tinker呢?
Tinker的已知问题
由于原理与系统限制,Tinker有以下已知问题:
1.Tinker不支持修改AndroidManifest.xml,Tinker不支持新增四大组件;
2.由于Google Play的开发者条款限制,不建议在GP渠道动态更新代码;
3.在Android N上,补丁对应用启动时间有轻微的影响;
4.不支持部分三星android-21机型,加载补丁时会主动抛出 "TinkerRuntimeException:checkDexInstall failed";
5.由于各个厂商的加固实现并不一致,在1.7.6以及之后的版本,tinker不再支持加固的动态更新;
6.对于资源替换,不支持修改remoteView。例如transition动画,notification icon以及桌面图标。
Tinker的demo
1.先去Github上下载Tinker源码,里面有tinker-sample-Android.
下好demo后,可能大家会迫不及待(其实就是我)跑起来,然后就回报这个错Error:Execution failed for task ':app:tinkerProcessDebugManifest'.
> tinkerId is not set!!!
wtf!然后赶紧百度,去查找wiki,哦哦,原来问题出在这里
tinker的官方文档这么写,当时我是懵圈的。
tinkerId is not set:这是因为没有正确的配置IDE的git路径, 若不是通过clone方式下载tinker,需要本地手动commit一次。这里你也可以使用其他字符作为tinkerId;
不过简单,网上肯定给出了答案:
String gitRec =”自己定义一个字符串”,不过建议这样写:(用你项目的versionName,也可以配置git路径)
好了,这个问题搞定了,那我们再来跑一次,现在是见证奇迹的时。。。wtf,什么鬼啊。。。我要不要面子的啊。
Error:A problem occurred configuringproject ':app'.
> Failed to notify project evaluationlistener.
> Tinker does not support instant run mode, please trigger build byassembleTestDebug or disable instant run in 'File->Settings...'.
> Task with name 'tinkerPatchTestRelease' not found in project':app'.
奔溃中。。
这个错误是说tinket不支持install run 模式 ,请手动build assembleDebug 或者把 install run 模式禁用掉。
其实只要把 install run模式关闭了,然后就可以运行成功了,如下图:(什么?install run怎么关?看这里:http://blog.csdn.net/u011663865/article/details/5310403)
<