[Android]如何做一个崩溃率少于千分之三噶应用app(5)-极速增量编译

以下是我这个系列的相关文章,有兴趣可以参考一下,可以给个喜欢或者关注我的文章。

[Android]如何做一个崩溃率少于千分之三噶应用app--章节列表


我建立了一个关于Android架构学习的群,里面可以进一步进行组件化学习的交流。

群号是316556016,也可以扫码进群。我在这里期待你们的加入!!!

[Android]如何做一个崩溃率少于千分之三噶应用app(5)-极速增量编译_第1张图片


如果大家有关注我,看到我这系列第三和第四篇文章的话,会看到我介绍的FaceBook的Buck编译,Buck编译是可以加速首次编译和之后的增量编译的。

但是近来我又发现,一种新的增量编译速度比instance run缩短了5倍以上,就系阿里开发的Freeline。


FreeLine真正的优势在于

1.真增量,构建过程快且增量包体积小,极大提升更改代码部署到手机速度,较Android studio2.0及 LayoutCast快3~5倍

2.跨平台Linux,mac,windows

3.全版本覆盖 2.x ~ 6.x版本均支持

4.部署流程简化,更改代码后,构建过程中,与手机建立了tcp长连接,一行命令即可完成增量部署,毋需到各自子bundle所在的目录构建完成后再进入portal/launcher进行打包再安装到手机的过程

5.事务支持,在开发过程引入的异常不会破坏工作空间

6.无缝支持mPass,解决了类似maven各个节点需merge合并等与常规开发流程不一致的问题

7.进程级别异常隔离,开发体验持续稳定


支持增量编译的范围

[Android]如何做一个崩溃率少于千分之三噶应用app(5)-极速增量编译_第2张图片


配置方式

1.工程主build.gradle添加

[Android]如何做一个崩溃率少于千分之三噶应用app(5)-极速增量编译_第3张图片

2.需要编译的项目的build.gradle里添加依赖

[Android]如何做一个崩溃率少于千分之三噶应用app(5)-极速增量编译_第4张图片


3.需要运行./gradlew initFreeline -Pmirror的命令

4.Application 的onCreate的代码需要添加 FreelineCore.init(this);

5.(1)可以添加android studio的插件在

Preferences → Plugins → Browse搜索freeline

   (2)可以使用命令行运行

./gradlew initFreeline

python freeline.py


这里是躺过的一些坑

1.这是基于Python编写的,所以只能运行于旧版本,例如2.7版本的python,新版本运行的时候会提示运行失败的。所以安装3.5版本的,可以再安装一个旧版本,然后配置环境变量

2.如果是使用MultiDex的话,需要在Application的attachBaseContext函数里面,super之后立刻添加MultiDex.install的函数,这样会绝大的减少class not found 的情况

3.Xml注释的时候不能出现例如 这样的注释(里面/** **/的注释号是多余的,要去掉),否则会运行出错。

4.Freeline编译只能增快增量编译,如果手机已经安装了原来的应用,需要安装一次Freeline编译的应用(第一次编译的时间是gradle编译的正常速度),不然之后用Freeline编译的增量编译会是无效的。

使用体验后,相比于Buck,Freeline不需要过多修改原有的的代码(Buck里面如果充斥着switch case的语句将会是噩梦),增量编译的速度也比Buck快,所以只需要忍受第一次编译比较缓慢。

想要了解相关的原理和分析,还是进入官网的介绍Freeline详细原理介绍

如果试用后出现特别的问题,欢迎一起讨论


*2016.11.14更新

发现如果创建布局,还有同时修改代码,有可能编译fail

这时候最好使用./gradlew initFreeline -f这个命令,重新全编一次是否还有问题。


*2016.11.25更新

在freeline.py文件里面,可以看到freeline的各种命令,只要加入这些后缀就可以运行了。(例如python freeline.py -f)

意思英文也解析得很清楚,这里就不作进一步解析啦。

[Android]如何做一个崩溃率少于千分之三噶应用app(5)-极速增量编译_第5张图片


*2017.1.4更新

有人反馈遇到这样的问题,编译不过

将这个换成22就可以编译通过了。


*2019.2.13

freeline现在已经不更新了,说一下现在的一些瓶颈问题

1.freeline不支持大部分的编译时注解工具,只支持databinding和dagger,在现在很多工程都使用编译时注解工具的情况将会如鸡肋。编译时注解如果没检测缓存的情况下会一直要求全编的,很影响编译速度。

2.freeline不支持kotlin编译,可以试着自己适配,网上有参考的文章。

你可能感兴趣的:([Android]如何做一个崩溃率少于千分之三噶应用app(5)-极速增量编译)