Android开发:《Gradle Recipes for Android》阅读笔记(翻译)6.1——推荐配置

问题:

你想要提高Gradle的构建效率。

解决方案:

使用下面推荐的技术组合。

讨论:

首先,这里没有可以影响app表现的建议。有很多你可以做的事来提高app,很多都和Android的混淆工具有关。这节不是关于这个的,这节是提高构建本身效率的。

这节讨论那些可以添加到应用根目录下的gradle.properties文件里面的设置。如果你更喜欢全局设置,home目录下面的.gradle的子文件夹下增加一个gradle.properties文件。

Gradle守护进程

Gradle守护进程是一个后台进程,在构建之间保持,缓存数据和代码。当你运行命令提示符时,最新的Gradle会自动的启动守护进程。

默认的,Android Studio在你的项目里面启动一个Gradle守护进程,持续三个小时,对于大部分开发任务都足够。如果你在命令行运行Gradle,你可能不能自动的启动守护进程。

为了确保守护进程的启动,可以增加下面的配置:

org.gradle.daemon=true

守护进程可以通过命令行标志启动或者停止。使用--daemon和--no-daemon可以在私人配置里面启用或者关闭守护经常。如果你担心内部缓存过期或者你正在测试,关闭守护进程是有效的。如果你想要停止一个正在运行的守护进程,可以使用--stop参数。

并行编译:

Gradle有个“孵化”选项用来并行编译独立的项目。使用它可以在gradle.properties里面增加一行:

org.gradle.parallel=true

这也许不会有太多用处,因为Android项目里面的modules大部分都是相关的,导致很难从并行编译里面获得好处。

按需求配置:

一般Gradle在排除一些任务之前为所有项目的都配置了所有的任务。对于一个有很多子项目和很多任务的项目,这不是很有效。所有可以尝试只配置那些和要求的任务相关的项目。

在gradle.properties使用“configure on demand”:

org.gradle.configureondemand=true

大部分Android应用都只有很少的子项目,所以这个特性并不总是有用。

这是一个潜伏的特性,所以特定的细节可能会在新版本的Gradle里面改变。

排除不要的任务:

在4.3节讨论过,-x标志可以用来排除指定的任务,像lint,耗时但是不是每次构建都需要运行的。

那节同样展示了如何在任务图里面排斥指定任务。

改变JVM设置:

根本上将一个Gradle构建是运行在java进程上的,所有那些影响JVM的参数也影响Gradle的表现。下面展示了一些JVM的设置(在gradle.properties里面):

org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m
    -XX:+HeapDumpOnOutOfMemoryError

-Xmx设置java进程使用的最大内存。-Xms设置初始分配给进程的内存。这个例子也改变了持久的空间大小,当java.lang.OutOfMemoryError抛出时,将堆栈存放文件里面。

可以到Java HotSpot VM页面查看更多细节。

只使用需要的依赖库:

这尤其值Google Play服务,经常需要大量的library,并且使用单独的模块。

例如,使用Google地图,你习惯在编译时添加完整的Google Play服务:

dependencies {
    compile ‘com.google.android.gms:play-service:7.8.0‘
}

这是一个庞大的库,有许多的依赖,一旦Google Play服务被添加下面一系列的library会被添加:

由于Android的65K方法名限制,你需要添加大量的你不需要的方法来处理。相反的,你可以只添加地图:

dependencies {
    compile ‘com.google.android.gms:play-service-maps:7.8.0‘
}

两者之间的差异是戏剧性的:

使用dex选项:

Android块允许你之指定“dex”进程的参数。dexOptions块包含下面的选项:

dexOptions {
    incremental true
    javaMaxHeapSize ‘2g‘
    jumboMode = true
    preDexLibraries = true
}

incremental选项设置是否启用增量模式。文档说“这有非常多的限制,可能不生效。慎重使用”。

使用javaMaxHeapSize作为指定Xmx的可选方法。

启用“jumbo mode”允许在dex文件中出现更多的字符串。如果这是一个问题,你应该花更多的时间配置混淆。

preDexLibraries会提前允许dx进程。文档描述:“这个可以提高增量构建效率,但是clean会变得慢”。

这些设置可以提高也可以降低表现,所以在确定使用它们之前进行试验。

列出配置的概况:

在命令行使用--profile运行Gradle,生成构建的有用信息。结果生成在build/reports/profile目录下的HTML里面。

举例,运行多flavor的assembleDebug任务,如下:

> ./gradlew --profile assembleDebug
:app:preBuild UP-TO-DATE
:app:preArrogantStarkDebugBuild UP-TO-DATE
:app:checkArrogantStarkDebugManifest
:app:preArrogantStarkReleaseBuild UP-TO-DATE
:app:preArrogantWayneDebugBuild UP-TO-DATE
:app:preArrogantWayneReleaseBuild UP-TO-DATE
:app:preFriendlyStarkDebugBuild UP-TO-DATE
:app:preFriendlyStarkReleaseBuild UP-TO-DATE
:app:preFriendlyWayneDebugBuild UP-TO-DATE
:app:preFriendlyWayneReleaseBuild UP-TO-DATE
:app:preObsequiousStarkDebugBuild UP-TO-DATE
:app:preObsequiousStarkReleaseBuild UP-TO-DATE
:app:preObsequiousWayneDebugBuild UP-TO-DATE
:app:preObsequiousWayneReleaseBuild UP-TO-DATE
// ... tons of other tasks ...
:app:assembleObsequiousWayneDebug
:app:assembleDebug

输出的文件在build/reports/profile文件夹下面,类似”profile-YYYY-MM-dd-hh-mm-ss.html“的文件名。

对于小的项目没有很多看的,但是对于大型项目,这是一个很好地途径来发现瓶颈。

时间: 2024-10-18 12:09:51

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)6.1——推荐配置的相关文章

Android开发工具全面转向Android Studio(3)——AS project/module的目录结构(与Eclipse对比)

如果AS完全还没摸懂的,建议先看下Android开发工具全面转向Android Studio(2)——AS project/module的CRUD. 1.其实AS project/module的目录结构很简单,我浓缩成2张图给总结了,先看图,再看下面的文字,因为还有些细节图上体现不出来(我这个图上的项目来源于我之前的Eclipse项目,并且有lib项目库相互依赖) 2.上面的图很直观,但也很眼花缭乱,我再针对图总结下重点和疑问点. ①在AS的世界里,文件夹都以模块(module)为单位组织的,其

配置cordova的android开发环境(无android studio)

原文:配置cordova的android开发环境(无android studio) 趁元旦放假想试一下cordova,不想安装庞大的android studio,所以想最小化安装,居然花了一整天的时间才能正常编译cordova工程,记录一下过程,备将来参考. 安装环境:操作系统:windows 10 x64 第一步:安装nodejs,下载最新版本v10.15.0 第二步:设置npm安装源 npm config set registry http://registry.npm.taobao.org

【Android开发】完美解决Android完全退出程序

背景:假说有两个Activity, Activity1和Activity2, 1跳转到2,如果要在2退出程序,一般网上比较常见的说法是用 System.exit(0) 或是 android.os.Process.killProcess(android.os.Process.myPid()) 但实际应用中,并不是能够真正退出,问题出在?1跳转到2时,如果Activity1你finish掉了,两么是可以退出程序的,但有时1跳转到2时,我们不能将Activity1 finish掉,那么在Activit

Android开发:《Gradle Recipes for Android》阅读笔记1.2

在android开发中会需要配置使用app的android SDK的最低版本和目标版本,这个是bulidl.gradle的android模块设置.默认有以下几个设置: applicationId,这个是应用的包名,在google应用商店里必须是唯一的,在app的整个生命周期里是不能修改的,修改后会被认为是一个新的app minSdkVersion,设置app支持的sdk最低的版本.在google应用商店里,低于这个版本的机器是看不到这个app的 targetSdkVersion,设置app的目标

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)6.2——DSL文档

问题: 你需要查找Android Gradle DSL的完整文档. 解决方案: 访问Gradle Tools网站,从Android开发网站下载ZIP文件. 讨论:Android开发网站首页有完整的API向导,Java相关文档,工具文档等.Android Gradle插件相关的内容却非常的少. Android Gradle插件的主要文档在点击这里,包含了最新的信息: 用户向导非常有用,但是经常过期...(这也是这本书存在的意义): 另外一个Android 插件工具的网站是DSL Reference

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)5.1——单元测试

问题: 你想要测试app中的非android部分. 解决方案: 可以使用Android Studio1.1里面增加的单元测支持和Android的Gradle插件. 讨论: ADT插件只支持集成测试,并且要求开发者创建一个单独的测试项目.转化到Android Studio和Gradle的其中一个好处就是支持在android项目内进行测试. 在AndroidStudio1.1之前和相关的Gradle插件,这些测试仍然被限制集成测试,意味着,你需要一个模拟器或者连接的设备才能进行测试.集成测试可以非常

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)2.3——用Eclipse ADT导出App

问题: 想在一个已经存在的Eclipse ADT的项目中使用Gradle 解决方案: Eclipse ADT插件可以帮助生成Gradle文件 讨论: Eclipse的ADT插件是在2013年推出Gradle之前主要的android开发工具.现在ADT项目被android studio所替代,但是还是有遗留的项目存在. ADT插件可以基于已经存在的项目结构和依赖帮你生成gradle的配置文件. 虽然这已经不是一个主流的机制,但是实践中会遇到这样的项目.这也是一个很好地机会,展示Gradle中的so

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)3.3——整合resource文件

问题: 想要在product的flavor里面改变图片,文字或者其它资源. 解决方案: 在flavor里面增加合适的资源目录,并且改变他们包含的值. 讨论: 考虑下3.2章的"hello world with attitude"应用,它定义了三个flavors:arrogant,friendly和obsequious.在每个情况下,app提示用户输入姓名,并且用这个姓名欢迎用户.每个的java代码都是相同的,但是看上去和感觉上好像每个都不一样. product的flavors在grad

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)3.1——使用Build Types

问题: 你想要自定义debug和release的build types,并且新建一些新的types. 解决方案: 使用buildTypes块配置build types. 讨论: build type决定了app如何被打包.默认的,android的gradle插件支持两种build type:debug和release.两种都在模块的build.gradle文件中的buildTypes块下定义.在新的项目下的buildTypes块如下: 例子中值显示了release的build,但是想要编辑默认配