Android Studio项目结构和Gradle应用

目前Android开发的主要IDE:Android Studio,相信很多Android程序猿都不陌生了。


今天主要介绍创建完一个Android的基本工程后整体的目录结构和每个文件的作用,还有一些gradle在Android Studio中最基本的应用。


下面是我创建的一个android demo,先粗略介绍每个文件的作用:



  • .gradle                    Gradle编译系统,版本由wrapper决定,展开后可以看到当前gradle版
  • .idea                       Android Studio IDE所需要的文件
  • app                         模块代码,撸代码的位置,其实里面就是Android代码和资源文件,后面会详细介绍里面的内容
  • Build                       代码编译后生成的文件存放的位置
  • Grade                     wrapper的jar和配置文件所在的位置
  • .gitignore                git使用的ignore文件,其实就是你在commit代码时,ignore中申明的一些文件不会上传到版本库中
  • build.gradle           项目的gradle编译文件,相当于整个项目的gradle配置文件。         
  • gradle.properties   gradle相关的全局属性设置,配置一些gradle的全局变量
  • gradlew                  *nix下可执行的编译脚本,其实这个就是gradle打包的命令
  • grdalew.bat            同上,windows下可执行的编译脚本
  • local.properties     本地配置文件,设置jdk路径或ndk等
  • MyApplication.iml   项目配置文件(自动生成)
  • settings.gradle        定义项目包含哪些模块,一般来说是用修改这个文件,但是如果你的项目有其他模块代码,就必须引入到setting.gradle中。

这里有几个文件需要详细说明一下:

首先看一下build.gradle:

buildscript {
    repositories {
        //构建过程依赖的仓库,gradle脚本自身需要的资源,有些时候也使用maven库
        jcenter()
    }
    dependencies {
        //定义gradle插件版本
        classpath ‘com.android.tools.build:gradle:1.5.0’

    }
}

allprojects {
    //这里指的是整个项目所有模块的资源
    repositories {
        jcenter()
    }
}

有的时候会看到subprojects的配置,这个是指针对所有子模块的配置除了主gradle。

然后是settings.gradle:

新建的工程只有一句话:

include ':app'

相当于把你的模块在这里进行注册,后续添加了其他模块的代码,只需要在后面继续添加,如:

include ':app',':car'

如果不在setting中注册car模块,那car模块只是一个普通的文件夹,gradle打包的时候不会把它包含进去,而且car模块也只是一个普通的文件夹。



========================我是分割线================================================


下面说一下app模块中的目录结构:



  • build                       编译后生成的文件,一般app模块都是程序的入口,所以一般build中会生成apk文件
  • libs                          放一些第三方jar包 
  • src                          源代码,这个不用过多说明了
  • .gitignore                和项目下的作用一样,只是一个是针对项目,这里是针对模块 
  • build.gradle             模块编译文件,包含一些模块依赖,相当于对该模块的gradle配置
  • proguard-rules.pro   混淆脚本

主要看一下build.gradle:

这个是整个app模块的gradle配置,


apply plugin: ‘com.android.application’  //声明插件,这是一个android程序,说明app 是整个项目的入口,如果只是模块库,则com.android.library

android {
    compileSdkVersion 23            //编译sdk的版本号
    buildToolsVersion “23.0.1”    //build tools版本号

    defaultConfig {
        //android构建过程中需要的参数
        applicationId “klc.com.myapplication”
        minSdkVersion 19
        targetSdkVersion 23
        versionCode 1
        versionName “1.0”
    }
    buildTypes {
        //这里面可以配置debug和release版本的一些参数,比如混淆、签名配置等
        release {
            minifyEnabled false   //是否开启混淆
            proguardFiles getDefaultProguardFile(‘proguard-android.txt’), ‘proguard-rules.pro’   //混淆文件位置
        }
    }
}

dependencies {
   //模块依赖
    compile fileTree(dir: ‘libs’, include: [‘*.jar’])  //依赖libs下所有jar包
    testCompile ‘junit:junit:4.12’
    compile ‘com.android.support:appcompat-v7:23.1.1’   //依赖appcompat库,相当于导入maven库
}

有几个地方请注意:

apply plugin这里一般app的入口都声明为'com.android.application',gradle会以这个为整个app的入口,所以会在改模块的build文件夹下生产apk文件,当然一个项目也可以有两个app的入口,相当于一个项目管理两个app,一般很少这样做。

一般其他模块直接声明为'com.android.library',这样就表示该模块是一个库了。


buildTypes,配置release版本和debug一些参数的区别,这里说一个gradle的bug,如果设置该模块为library,这里的debug参数是无效的,都是走release中的配置。


dependencies,如果想引用其他模块的代码就需要在这里声明,如想要app中使用car的代码,要加入:

compile project ':car'

这样就可以在app中引用car模块的代码了,前提是car模块是声明为了‘com.android.library’,而且在setting.gradle中注册了。





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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值