以HelloWorld工程为例,在ApplicationTest.java中,
import android.app.Application;
import android.test.ApplicationTestCase;
/**
* <a href=" http://d.android.com/tools/testing/testing_android.html">Testing Fundamentals</a>
*/
public class ApplicationTest extends ApplicationTestCase<Application> {
public ApplicationTest() {
super(Application.class);
}
}
main文件夹下的与eclipse中的文件构造相同。
test文件夹下ExampleUnitTest.java:是用来编写Unit Test测试用例的,是对项目进行自动化测试的另一种方式。----《第一行代码》,但具体的怎么用不知道,又一个问题出现了。以后再补充。
app文件夹下的其他文件介绍:
build文件夹:和外层的build目录类似,主要也是包含一些在编译时自动生成的文件,不过它里面的内容会更多更复杂。
libs文件夹:eclipse中也有这个文件夹,放项目中使用到的第三方.jar包,这与“external libraries”有什么不同?以后再补充。
.gitignore:这个文件用于将app模块内的指定的目录或文件排除在版本控制之外,作用和外层的.gitignore文件类似。关于版本控制我还没学到,以后再补充。
app.iml:IntelliJ IDEA项目自动生成的文件。(IDEA 全称 IntelliJ IDEA,是java语言开发的集成环境)
build.gradle:是app模块的gradle构建脚本,这个文件中会指定很多项目构建相关的配置。(脚本,是使用一种特定的描述性语言,依据一定的格式编写的可执行文件,又称作宏或批处理文件。)
proguard-rules.pro:这个文件用于指定项目代码的混淆规则,当代码开发完成后打成安装包文件,如果不希望代码被别人破解,通常会将代码进行混淆,从而让破解者难以阅读。
详解bulid.gradle文件---《第一行代码》,目前由于按照第一行代码开始学习,当前阶段的博文基本上都属于该书的笔记,以后会省略“摘自《第一行代码》”等字样。
以前下载别人的代码,在自己的Android studio上运行时,第一步好像就是把build.gradle中的一些关于版本的东西给改了。
1、最外层目录下的build.gradle:
buildscript { //脚本创建
repositories { //仓库
jcenter() //jcenter是一个代码托管仓库,很多Android开源项目都会选择将代码托管到jcenter上,声明了这行配置之后,我们就可以在项目中轻松引用任何jcenter上是开源项目。怎么用?见:http://www.cnblogs.com/shiwei-bai/archive/2015/11/24/4991636.html
}
dependencies {
classpath 'com.android.tools.build:gradle:2.1.2'//com.android.tools.build:gradle:2.1.2这是一个gradle插件,如果要用gradle创建Android项目,需要它。
// 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
}
2、app文件夹下的build.gradle:
apply plugin: 'com.android.application' //应用了一个插件,一般有两种值可选:com.android.application,表示这是一个应用程序模块;com.android.library,表示这是一个库模块,只能作为代码库依附于别的应用程序模块来运行。
android {
compileSdkVersion 25 //用于指定项目的编译版本
buildToolsVersion "25.0.2" //用于指定项目构建工具的版本
defaultConfig {
applicationId "com.example.xinxing.helloworld"//用于指定项目的包名
minSdkVersion 15 //用于指定项目最低兼容的Android系统版本
targetSdkVersion 25 //目标版本上已经做过了充分的测试,系统将会为你的应用程序启用一些最新的功能和特性
versionCode 1 //用于指定项目的版本号
versionName "1.0" //用于指定项目的版本名
}
buildTypes { //buildTypes闭包中用于指定生成安装文件的相关配置,通常只会有两个子闭包,一个是debug,一个是release。debug闭包用于指定生成测试版安装文件的配置,release闭包用于指定生成正式安装文件的配置。另外,debug闭包是可以忽略不写的。
release {
minifyEnabled false //用于指定是否对项目的代码进行混淆
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' //用于指定混淆时使用的规则文件,这里指定了两个文件,第一个proguard-android.txt是Android SDK 目录下的,里面是所有项目通用的混淆规则,第二个proguard-rules.pro是在当前项目的根目录下的,里面可以编写当前项目特有的混淆规则。
}
}
}
dependencies { //可以指定当前项目所有的依赖关系,通常Android studio项目有3种依赖方式:本地依赖、库依赖、远程依赖。本地依赖可以对本地的jar包或目录添加依赖关系,库依赖可以对项目中的库模块添加依赖关系,远程依赖则可以对jcenter库上的开源项目添加依赖关系。
compile fileTree(dir: 'libs', include: ['*.jar']) //本地依赖声明,表示将libs文件夹下的所有.jar文件都添加到项目的构建路径中
testCompile 'junit:junit:4.12' //声明测试用例库
compile 'com.android.support:appcompat-v7:25.3.0' //远程依赖声明,com.android.support:appcompat-v7:25.3.0,是一个标准的远程依赖库格式,其中com.android.support是域名部分,用于和其他公司的库做区分;appcompat-v7是组名称,用于和同一公司中不同的库做区分;25.3.0是版本号,用于和同一个库不同的版本作区分。加上这句声明后,gradle在构建项目时会首先检查一下本地是否已经有了这个库的缓存,如果没有就会自动联网下载,然后再添加到项目的构建路径中。
//库依赖声明形式:compile project后面加上要依赖的库名称,比如说有一个库模块的名字是helper, 那么库依赖为:compile project(':helper')
}