摘要:接下来的一段时间会对的相关知识进行梳理,所以借此整理成一个系列。所以不仅支持还支持等。所以是位于的最外层,即与同级。根据后面的提示,发现它们分别来自与与。它会在运行时注入到相应的中。
接下来的一段时间会对Android Gradle的相关知识进行梳理,所以借此整理成一个系列。如果你是刚入行的新秀,那么这个系列将会非常适合你,因为Android基本的配置都与Gradle有关。当然如果你已经入行,但对Gradle还是停留在表面的认知上,这个系列也会对你有所帮助。
这篇文章定义为入门篇,将结合自己刚开始学习Android时的疑惑与现在对Gradle的认识,进一步整理Gradle在Android中的整体结构。
思考当我使用Android Studio时,一直有几个疑问围绕着我:
Android Studio是怎样将Java与Kotlin代码的编译成APK文件?
Gradle是怎样将Java与Kotlin代码编译成APK文件?
后来知道Android Studio自身是不能够编译成APK的,它是集成了Gradle。通过研究Gradle,发现Gradle也只是一个构建工具,真正编译成APK的功能是由Android app plugins提供的。Gradle只是自动化构建工具,提供构建时的各种生命周期,例如:building、testing、publishing等。所以Gradle不仅支持Android还支持C/C++、Scale等。
而这个plugin其实就是在project中的build.gradle中声明的classpath
buildscript { repositories { // Gradle 4.1 and higher include support for Google"s Maven repo using // the google() method. And you need to include this repo to download // Android Gradle plugin 3.0.0 or higher. google() ... } dependencies { classpath "com.android.tools.build:gradle:3.4.0" } }
所有每次对Android构建进行了优化,我们都要来更新这个版本。
Scripts有了上面的基础,当我们新建一个Android项目时,你将会看到如下与Gradle相关的文件:
你会看到文件名几乎都有gradle字段,下面我会一一介绍它们的作用
Gradle Wrapper首先是gradle-wrapper.properties文件,打开它你将会看到如下类似信息
#Sat Jan 19 08:25:46 CST 2019 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists distributionUrl=https://services.gradle.org/distributions/gradle-4.6-all.zip
这个是gradle版本的配置项,申明你当前项目中使用的gradle版本。当我们构建项目的时候,它会根据版本自动下载。并且保存到你的电脑本地中。如果你使用的是Mac,你可以使用如下命令查看你的所有已经下载的gradle版本。
ls ~/.gradle/wrapper/dists/
所以如果你不满意当前版本,也可以通过查看version of Gradle修改到相应的版本
settings.gradle这个文件是项目与其子项目或者module间的配置。里面通过include函数来告诉该项目所包换的子项目或者依赖的module。例如刚新建项目时只有一个app子项目。
include ":app"
所以settings.gradle是位于project的最外层,即与app同级。
build.gradle现在我们已经知道一个project可以包含一个或者多个sub-projects,而Android一般会将sub-projects当做module,所以你会在这看到两个build.gradle。根据后面的hint提示,发现它们分别来自与project与module。
首先我们来看project中的build.gradle,即位于根目录下的文件
buildscript { //1 ext.objectboxVersion = "2.3.0" //4 repositories { //2 google() jcenter() } dependencies { //3 classpath "com.android.tools.build:gradle:3.3.2" classpath "io.objectbox:objectbox-gradle-plugin:$objectboxVersion" } } allprojects { //5 repositories { google() jcenter() } } task clean(type: Delete) { //6 delete rootProject.buildDir }
buildscript闭包是申明编译该项目所需的相关配置
告知gradle这些配置将从google()与jcenter()中获取
申明相关的plugin,例如Android Plugin for Gradle。
在gradle中有一个extra property属性,允许我们通过它来申明一些变量,例如plugin的版本号。有一个特性就是这些变量在gradle中都是全局的。所以对于多个module时,我们可以通过它来统一相关的版本号。最后在3中通过${name}来引用
因为可能有多个sub-project,对于一些相同的配置,可以通过allprojects来进行统一管理。
申明一个task,用来执行相关任务,这里是clean操作,目的是删除build文件夹中的数据
下面是module中的build.gradle
apply plugin: "com.android.application" apply plugin: "io.objectbox" //1 android { //2 compileSdkVersion 28 defaultConfig { minSdkVersion 21 targetSdkVersion 27 versionCode 100005 versionName "1.0.5" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" } } } dependencies { //3 implementation fileTree(include: ["*.jar"], dir: "libs") implementation "com.android.support:appcompat-v7:28.0.0" implementation "com.android.support:support-v4:28.0.0" }
通过调用apply函数,引入我们需要依赖的plugin,这个就是我们在根build.gradle中申明的classpath
android闭包是gradle最重要的配置申明,例如默认的配置信息defaultConfig,包含minSdkVersion最小支持的android版本,versionCode与versionName等。这些配置都与编译息息相关,最好你应该熟悉它们。你实在记不住的话,我这里也有秘籍,AppExtension这里面包含所有的配置项与所代表的意义。
这里的dependencies用来申明项目所依赖的第三方库,而这些库的获取来源无需再次申明,因为我们已经在之前的根目录的build.gradle中的allprojects闭包中进行了申明。再者之前的ext全局变量也可以在这里使用。
gradle.properties这个文件一般都是本地文件,主要用来对gradle构建的一些个人配置项。例如gradle运行是否并行,gradle的jvmargs大小、是否开启daemon等等。它会在gradle运行时注入到相应的build.gradle中。
local.properties这个文件也是本地文件,只不过它用来配置gradle之外的配置信息,例如ndk与sdk目录,或者一些敏感的信息,例如插件开发打包上传到远程仓库这时可能需要账号、密码、api_key等,防止打包时暴露。
Gradle Tasksgradle tasks是用来执行特定的gradle任务的。我们可以直接点击Android Studio右边的Gradle按钮,你会发现在Tasks下会列出该项目的所用可执行的gradle任务。
或者你也可以在命令行中执行如下命令,查看app下的所有tasks
./gradlew app:tasks
我们顺便点击一个,例如assembleDebug,我们将会在Run日志系统中看到如下执行结果
根据输出的日志,也标明它是执行了task: assembleDebug
当然我们也可以在命令行执行指定的task,例如要达到上面相同的效果,我们可以输入如下命令
./gradlew assembleDebug --console plain
./gradlew 代表的是使用Gradle Wrapper中的gradle,就是该项目本身的gradle版本,避免直接使用gradle命令
assembleDebug是task的名称
--console plain输出完整的日志
既然说到这里,再说一个初级者容易做的无意义的操作。有时会碰到一些问题而去点击Clean Project,再点击Rebuild Project。其实Clean Project是不必要的。我们可以直接先点击Rebuild Project,查看日志
结果是它分别执行了task: clean,assembleDebug。所以Rebuild Project就已经包含了Clean Project,我们无需多此一举执行Clean Project。
嗯,就这些。最后,希望这篇文章,能够让大家对gradle在项目中的结构与所处的地位有一个更清晰的理解。
想更多的了解我,亦或者对我的文章感兴趣的可以关注我的公众号,及时获取最新动态~
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/74437.html
摘要:上周我们在系列入门篇文章中已经将在项目中的结构过了一遍。但是不同的是它可以改变其自身的代理。这正常,因为我们还没有声明它。与将通过对象进行。至于是的中的一个抽象感念,它申明在中。的知识点还有很多,这只是对有关的一部分进行分析。 showImg(https://segmentfault.com/img/bVbsh3m?w=2560&h=1280); 上周我们在Android Gradle...
阅读 1567·2023-04-26 02:29
阅读 3053·2021-10-11 10:58
阅读 2900·2021-10-08 10:16
阅读 3160·2021-09-24 09:47
阅读 1568·2019-08-29 16:56
阅读 2720·2019-08-29 11:03
阅读 2004·2019-08-26 13:35
阅读 3173·2019-08-26 13:34