前几天,万众期待的微信团队的Android热修复框架tinker终于在GitHub上开源了。
地址:https://github.com/Tencent/tinker
官方介绍:https://my.oschina.net/shwenzhang/blog/751618
接入指南:https://github.com/Tencent/tinker/wiki/Tinker-%E6%8E%A5%E5%85%A5%E6%8C%87%E5%8D%97
今天拿下来集成使用了一下,发现md上对集成使用的过程介绍的比较精简(后来发现wiki上面倒是很详细,需要的同学可以自己去看),这里记录一下我集成使用的过程。
一、集成
我这里直接使用的是他1.6.2版本(1.6.0-1.6.3集成与使用的应该都类似,但是1.7.0以及以后,修改比较大,配置与使用略有不同)自带的sample,导入到studio中。
二、初始化配置
首先我们需要在app/bulid.gradle中,设置tinkerId的值,很多人开始编译就报错,提示“tinkerId is not set!!!”,就是因为这个值没有设置。获取tinkerId走的
def gitSha() {
return 'git rev-parse --short HEAD'.execute().text.trim()
}
这个方法,也就是获取git最近一次commit的版本号,所以要是你的当前Project没有配置git,或者当前的Project还没有commit过,或者git没有加入到环境变量中,会获取不到该值。知道了原理,那解决方式就自己想了,我这里就直接写死,上面这个方法直接返回固定字符串。
---------------------------------------------------------------------------
补充:关于获取git提交版本号
git rev-parse --short HEAD
这段代码主要是用来显示最近一次提交到远程仓库上revision的编号(类似于“b03b0c4”的字符串。个人对git命令行了解不多,如果有知道的大神麻烦指教一下)。
所以前面说的,除了环境变量配置好git(可以在命令行输入 git --version ,显示出了版本号,便是配置成功),再把你的项目与git关联起来,并且保证有一次commit记录,才能获取到该字符串。
具体使用可以看我的另一篇文章:关于git命令“git rev-parse --short HEAD”在android studio中使用与配置的个人探究
我在使用sample时先直接写死了。正式应用到项目上时,可以根据自己的实际情况来配置该参数。
---------------------------------------------------------------------------------------------------
之后,我们会看到Manifest.xml中,SampleApplication.java这个类报红找不到。这个并不影响,因为到时候我们在编译的时候,tinker会为我们生成SampleApplication.java这个类,而起作用的代码就是SampleApplicationLike.java类声明上面的
@DefaultLifeCycle(application = "tinker.sample.android.app.SampleApplication&#