bulid.gradle 解析

外层的bulid.gradle文件


buildscript {
    repositories {
        jcenter()   // 一个代码托管仓库
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.0' // 声明一个gradle插件
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

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

两处的repositories的闭包中都声明了jcenter() 这行配置。
jcenter是一个代码托管仓库,很多Androdi开源项目都会选择将代码托管到jcenter上,声明了这个配置之后,可以在项目中引用任何jcenter上的开源项目。


dependencies闭包使用classpath声明一个gradle插件。gradle并不是专门为构建android项目而开发,使用它时,需要声明com.android.tools.build:gradle+版本号

app目录内的build.gradle文件

apply plugin: 'com.android.application' 

android {
    compileSdkVersion 25    //指定项目的编译版本
    buildToolsVersion "25.0.2" //指定项目构建工具的版本
    defaultConfig {
        applicationId "com.example.hwy01.myfirstapp"  //指定项目的包名
        minSdkVersion 15  
        targetSdkVersion 25
        versionCode 1 //指定项目的版本号
        versionName "1.0" //指定项目的版本名
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {    //用于指定生成安装文件的相关配置
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies 
{   //指定当前项目所有的依赖关系
    compile fileTree(dir: 'libs', include: ['*.jar']) //本地依赖声明,表示将libs目录下所有的.jar后缀的文件都添加到项目的构建路径中
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:25.2.0' //标准的远程依赖库格式
    compile 'com.android.support.constraint:constraint-layout:1.0.2'
    testCompile 'junit:junit:4.12' //用于声明测试用例库的
}

第一行是应用了一个插件,一般有2个值可选:

  • com.android.application表示这是一个应用程序模块
  • com.android.library 表示这是一个库模块。

应用程序模块和库模块的最大区别是,一个可以直接运行,一个只能作为代码库依附于别的应用程序模块来运行。

buildTypes闭包用于指定生成安装文件的相关配置。通常只有2个子闭包:debug和release

  • debug闭包用于指定生成测试版安装文件的配置
  • release闭包用于指定生成正式版安装文件的配置

debug闭包可以忽略不写。

release闭包详解

  • minifyEnabled 用于指定是否对对项目的代码进行混淆。 true表示混淆,false表示不混淆。
  • proguardFiles用于指定混淆时使用的规则文件。

proguard-android.txt 是在Android SDK目录下的,里面是所有项目通用的混淆规则。
proguard-rules.pro 是在当前项目根目录下的,里面可以编写当前项目特有的混淆规则

通过Android Studio直接运行项目生成的都是测试版安装文件

dependencies闭包 指定当前项目所有的依赖关系

通常Android Studio项目一共有3种依赖方式:

  • 本地依赖
    可以对本地的jar包或目录添加依赖关系
  • 库依赖
    可以对项目中的库模块添加依赖关系
  • 远程依赖
    可以对jcenter库上的开源项目添加依赖关系

compile 'com.android.support:appcompat-v7:25.2.0' 标准的远程依赖库格式
com.android.support是域名部分,用于和其他公司的库做区分。
appcompat-v7是组名称,用于和同一个公司中不同的库做区分。
25.2.0 是版本号,用于和同一个库不同的版本做区分。

你可能感兴趣的:(bulid.gradle 解析)