Android build.gradle文件详解(转述自《Android第一行代码》第二版)


以下内容都是记录的《Android第一行代码》(郭霖·第二版)中的内容。
Gradle是一个非常先进的项目构建工具,它使用了一种基于Groovy的领域特定语言(DSL)来声明项目设置,摒弃了传统基于XML(Ant和Maven)的各种繁琐配置。
Android项目有两个build.gradle文件,一个在最外层的目录下,一个是在app目录下。这两个文件对构建Android Studio项目都起到了至关重要的作用。

1. 最外层目录下的build.gradle文件

下面是文件代码,直接从项目中复制出来的

buildscript {
    repositories {
        google()
        jcenter()

    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.4.2'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        maven { url "https://raw.github.com/bmob/bmob-android-sdk/master" }
        maven { url 'https://www.jitpack.io' }
    }
}

这些代码都是自动生成的,如果需要自己添加也是可以的。新人的话不用看语法结构,直接看最关键的部分。

1.1 repostories

首先,两处repositories的闭包中都声明了jcenter()这行配置,这个jcenter()其实就是一个代码托管仓库,很多Android开源项目都会选择项代码托管到jcenter上,声明了这行配置后,我们就可以在项目中轻松引用任何jcenter()上的开源项目了。还有上面代码中配置的google()也是一个道理。maven关键字时属于引入的单个开源项目。

1.2 dependencies

dependencies闭包中使用classpath声明了一个Gradle插件。因为Gradle不是专门为构建Android项目开发的,Java、C++等很多项目都可以使用Gradle来构建。因此如果是想构建Android项目,就需要声明‘com.android.tools.build:gradle:3.1.4’这个插件。其中,最后面的部分是插件的版本号。
通常情况下不需要修改这个文件中的内容,除非想添加一些全局的项目配置。

2. app目录下的build.gradle文件

下面代码都是我自己项目中复制出来的,有文章中没有说到的地方,可以暂时忽略。

apply plugin: 'com.android.application'

android {
    compileSdkVersion 29
    buildToolsVersion "29.0.0"
    defaultConfig {
        applicationId "com.timemanagersystem"
        minSdkVersion 19
        targetSdkVersion 29
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
    useLibrary 'org.apache.http.legacy'
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'androidx.appcompat:appcompat:1.1.0'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test:runner:1.2.0'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'

    implementation 'cn.bmob.android:bmob-sdk:3.7.3-rc1'
    implementation "io.reactivex.rxjava2:rxjava:2.2.2"
    implementation 'io.reactivex.rxjava2:rxandroid:2.1.0'
    implementation 'com.squareup.okio:okio:2.1.0'
}
2.1 apply plugin

第一行应用了一个插件,一般有两种值可以选:com.android.application 表示这是一个应用程序模块,com.android.library表示这是一个库模块。应用程序模块和库模块最大的区别在于,一个是可以直接运行的,一个只能作为代码库依附于别的应用程序模块来运行。

2.2 android

在android闭包中,我们可以配置项目构建的各种属性。

  • compileSdkVersion:用于指定项目的编译版本,这里的29好像是Android 10的SDK。
  • buildToolsVersion:用于指定项目构建工具的版本。
  • defaultConfig:在这个闭包中,可以对项目进行更多的细节配置。applicationId用于指定项目的包名,在项目创建的时候,就已经指定过包名了,如果需要改的话,就在这里改。-minSdkVersion用于指定项目最低兼容的Android系统版本,这里为19,表示最低兼容Android 4.4系统。targetSdkVersion指定的值表示在该目标版本上已经做了充分的测试,系统将会为你的应用程序启用一些最新的功能和特性。比如说Android 6.0 系统中引入了运行时权限这个功能,如果你想targetSdkVersion指定成23或者更高,那么系统就会为你得程序启用运行时权限这个功能,而如果想targetSdkVersion指定成22,那么就说明你的程序最高只在Android 5.1 上做过充分测试,Android 6.0 系统引入的新功能就不会启用了。
  • versionCode:用于指定项目的版本号。
  • versionName:用于指定项目的版本名。
2.3 buildTypes

buildTypes闭包用于指定生成安装文件相关配置,通常只会有两个子闭包,一个是debug,一个是release。debug闭包用于指定生成测试版安装文件的配置,release闭包用于指定生成正式安装文件的配置。debug闭包可以忽略不写。release闭包中的minifyEnabled用于指定是否对项目的代码进行混淆,true表示混淆,false表示不混淆。proguardFiles用于指定混淆时使用的规则文件,这里指定了两个文件,第一个proguard-android.txt是在Android SDK目录下的,里面是所有项目通用的混淆规则,第二个proguard-rules.pro是在当前项目的根目录下的,里面可以编写当前项目特有的混淆规则。

2.4 dependencies

dependencies闭包中指定当前项目所有的依赖关系。通常一个Android Studio项目一共有三种依赖方式:本地依赖,库依赖和远程依赖。本地依赖可以对本地的jar包或者目录添加依赖关系,库依赖可以对项目中的库模块添加依赖关系,远程依赖则可以对jcenter库上的开源项目添加依赖关系。第一行implementation fileTree是一个本地依赖的声明,表示将libs目录下所有.jar文件都添加到项目的构建路径中。第二行的**implementation **是声明远程依赖,在“androidx.appcompat:appcompat:1.1.0” 中“androidx.appcompat”是域名,用于和其他公司的库做区别,“appcompat”是组名称,用于区别同一个公司中不同库,“1.1.0”是版本号。
声明后,在构建项目是会先检查本地是否已经有了这些库的缓存,没有的话会自动联网下载,然后添加到编译路径中。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值