5.详解build.gradle文件

    我之前所开发的java项目都是使用Maven构建的,而安卓项目则是通过gradle构建的。

    我们在之前分析安卓项目的目录结构的时候,可以看到build.gradle有两个,一个是位于最外层的,一个是位于app目录下的,这两个文件都对构建安卓项目都起着至关重要的作用。先来看看最外层的build.gradle

buildscript {
    repositories {
        google()
        jcenter()
        
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.3.0'
        
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

     这些代码都是自动生成的,虽然看上去有点难以理解,我们忽略它的语法结构,只看最关键的部分,首先两处repositories的闭包中都声明了jcenter()这行配置,这行配置的意思是一个代码托管库,很多的Andriod开源项目都会托管到jcenter上,声明了这行配置后,我们就可以在项目中轻松的引用任何的jcenter上的开源项目了,同理google()也是如此。

    接下来,dependencies    闭包中使用classpath    声明了一个Gradle插件。为什么要声明这个 插件呢?因为Gradle并不是专门为构建Android项目而开发的,Java、C++等很多种项目都可以使 用Gradle来构建。因此如果我们要想使用它来构建Android项目,则需要声 明com.android.tools.build:gradle:3.3.0    这个插件。其中,最后面的部分是插件的 版本号,我在写作本书时最新的插件版本是3.3.0。

    下面,我们分析一下app目录下的build.gradle,代码如下:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "example.com"
        minSdkVersion 15
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

    我们逐行的分析:

    第一行

    apply plugin: 'com.android.application',第一行应用了一个插件,一般有两个可供选择的值,com.android.application:表示这是一个应用程序的模块,是可以直接运行的。另一个可供选择的值是com.android.library,表示是一个库模块,它只能作为代码库依附于别的应用程序模块来运行。

       接下来是一个android的大闭包,在这个闭包中我们可以配置项目构建的各种属性。其中compileSdkVersion 28用于指定项目的编译版本,这里指定为28表示使用的Andriod9.0的SDK编译。然后我们看到,这里在android闭包中又嵌套了一个defaultConfig闭包    ,defaultConfig闭包中可以 对项目的更多细节进行配置。其中,applicationId    用于指定项目的包名,前面我们在创建 项目的时候其实已经指定过包名了,如果你想在后面对其进行修改,那么就是在这里修改 的。minSdkVersion    用于指定项目最低兼容的Android系统版本,这里指定成15表示最低兼容 到Android    4.0系统。targetSdkVersion    指定的值表示你在该目标版本上已经做过了充分的测 试,系统将会为你的应用程序启用一些最新的功能和特性。比如说Android    6.0系统中引入了运 行时权限这个功能,如果你将targetSdkVersion    指定成23或者更高,那么系统就会为你的 程序启用运行时权限功能,而如果你将targetSdkVersion    指定成22,那么就说明你的程序 最高只在Android    5.1系统上做过充分的测试,Android    6.0系统中引入的新功能自然就不会启用 了。剩下的两个属性都比较简单,versionCode    用于指定项目的版本号,versionName    用于
指定项目的版本名,这两个属性在生成安装文件的时候非常重要,我们在后面都会学到。分析完了defaultConfig闭包,接下来我们看一下buildTypes闭包    。buildTypes闭包中用于指定生 成安装文件的相关配置,通常只会有两个子闭包,一个是debug,一个是release。debug闭包用于 指定生成测试版安装文件的配置,release闭包用于指定生成正式版安装文件的配置。另外, debug闭包是可以忽略不写的,因此我们看到上面的代码中就只有一个release闭包。下面来看一 下release闭包中的具体内容吧,minifyEnabled    用于指定是否对项目的代码进行混淆,true 表示混淆,false    表示不混淆。proguardFiles    用于指定混淆时使用的规则文件,这里指定 了两个文件,第一个proguard-android.txt    是在Android    SDK目录下的,里面是所有项目 通用的混淆规则,第二个proguard-rules.pro    是在当前项目的根目录下的,里面可以编写 当前项目特有的混淆规则。需要注意的是,通过Android    Studio直接运行项目生成的都是测试版 安装文件,关于如何生成正式版安装文件我们将会后面学习。

       这样整个android闭包中的内容就都分析完了,接下来还剩一个dependencies闭包    。这个闭包的 功能非常强大,它可以指定当前项目所有的依赖关系。通常Android    Studio项目一共有3种依赖方 式:本地依赖、库依赖和远程依赖。本地依赖可以对本地的Jar包或目录添加依赖关系,库依赖 可以对项目中的库模块添加依赖关系,远程依赖则可以对jcenter库上的开源项目添加依赖关系。 观察一下dependencies闭包中的配置,第一行的compile    fileTree    就是一个本地依赖声明, 它表示将libs目录下所有.jar后缀的文件都添加到项目的构建路径当中。而第二行的compile    则 是远程依赖声明,com.android.support:appcompat-v7:24.2.1    就是一个标准的远程依 赖库格式,其中com.android.support    是域名部分,用于和其他公司的库做区 分;appcompat-v7    是组名称,用于和同一个公司中不同的库做区分;24.2.1是版本号,用于 和同一个库不同的版本做区分。加上这句声明后,Gradle在构建项目时会首先检查一下本地是否 已经有这个库的缓存,如果没有的话则会去自动联网下载,然后再添加到项目的构建路径当 中。至于库依赖声明这里没有用到,它的基本格式是compile    project    后面加上要依赖的库 名称,比如说有一个库模块的名字叫helper,那么添加这个库的依赖关系只需要加入compile project(':helper')    这句声明即可。另外剩下的一句testCompile    是用于声明测试用例 库的,这个我们暂时用不到,先忽略它就可以了。

你可能感兴趣的:(Android)