第一行代码笔记(2)

Andriod studio 采用Gradle来构建项目

第一行代码笔记(2)_第1张图片
image.png

一般一个项目有两个build.gradle,一个在最外层目录下,一个在app目录下面:


第一行代码笔记(2)_第2张图片
image.png
buildscript {
    
    repositories {
        google()
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.0.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
}

这些代码都是自动生成,请忽略语法结构,只需看最关键的部分:
1.两处repositories的闭包都声明了jcenter()这一行,jcenter()是一个代码托管仓库,很多安卓开源项目都会选择将代码托管到jcenter上,声明了他之后,就可以在此项目中引用jcenter中的任何开源项目了,
2.dependencies闭包中使用classpath声明了一个gradle插件,why要有这个插件,gradle不是专门为构建安卓项目而生,java,c++很多项目都可以用它创建,想要用它来构建安卓项目,必须用声明com.android.tools.build:gradle:3.0.0这个插件,后面部分表示版本号;
这是最外层目录下的gradle解析一般情况下并不需要修改此文件,除非想添加一些全局性的项目构建配置;
下面看一看app下面的build.gradle:

apply plugin: 'com.android.application'

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

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

第一行应用了一个插件,有两种值可以选,com.android.application表示这是一个应用程序模块,com.android.library表示这是一个库模块;这两者的区别在于:前者可以直接运行,后者只能作为代码库依附于别的应用程序模块来运行;接着是最大的一个安卓闭包,在这个闭包中可以配置项目构建的各种属性:
compileSdkVersion表示指定项目的编译版本;
//buildToolVersion用于指定项目构建工具的版本
androdid闭包中又嵌套了一个defaultConfig闭包,defaultConfig闭包中可以对项目的更多细节进行配置。
applicationId用于指定项目的包名,前面我们在创建项目的时候已经指定过包名了,如果你想在后面对其进行修改,那么就是在这里进行修改的;
mindsdkVersion用于指定项目最低兼容的Android系统版本,这里15表示最低兼容到Androdid4.0版本;
targetsdkVersion指定的值表示在该目标版本上已经做过了充分的测试,系统将会为你的应用程序启用一些最新的功能和特性;
下面看一看buildTypes闭包:
buildTypes用于指定生成安装文件的相关配置,通常只会有两个子闭包,一个是debug,一个是release;debug闭包用于生成测试版安装文件的配置,release闭包用于指定生成正式版安装文件的配置;debug可以忽略不写;
minifyEnabled 用于指定是否对项目的代码进行了混淆,true表示混淆,false表示没有;
proguardFiles 用于指定混淆时指定的规则文件,这里指定了两个文件,
proguard-android.txt是在android sdk目录下的,里面是所有项目通用的混淆规则;proguard-rules.pro是在当前项目的根目录下的,里面可以编写当前项目特有的混淆规则;
最后还剩一个dependencies闭包,可以指定当前项目的所有依赖关系,通常一个android Studio项目一共有3种依赖方式:本地依赖,库依赖,远程依赖:
本地依赖可以对本地的jar包或者目录添加依赖关系;
库依赖可以对项目中的库模块添加依赖关系;
远程依赖则可以对jcenter库上的开源项目添加依赖关系;
implementation fileTree是本地依赖声明,它表示将libs目录下所有被的.jar后缀文件都添加至项目的构建路径当中;
implementation:远程依赖声明,com.android.support:appcompat-v7:26.1.0'是一个标准的远程依赖库格式,com.android.support是域名部分,用于和其他公司的库做区分;appcompat-v7是一个组区分,用于和同一个公司的不同库区分;26.1.0是版本号,用于和同一个库的不同版本号做区分;加上这一句声明之后,ggradle首先会在构建项目时检查一下本地是否含有这个库的缓存,没有会自动联网下载,然后再添加至项目的构建路劲当中,
而库依赖声明的基本格式是:implementation project后面加上依赖库的名字,比如一个库模块的名字叫helper,implementation project(':helper')这句声明即可;
testImplementation是用于声明测试用例库的,暂时用不到

你可能感兴趣的:(第一行代码笔记(2))