Gradle 依赖管理

2018-05-19  本文已影响0人  幽_27db
仓库

远程仓库:专门用来提供给开发者使用的依赖库
gradle通过远程仓库帮助开发者管理依赖,gradle不会默认为项目添加任何仓库。gradle支持三种仓库:maven、Ivy和文件夹。依赖包会在开发者执行build任务时从远程仓库下载下来,gradle会保留缓存,所以同个版本的依赖包只需要下载一次。
一个依赖需要定义三个元素:group,name和version.

仓库预定义
repositories {
        jcenter()
        google()
    }

jcenter是maven中心库的一个分支,支持HTTPS,但maven不支持https

远程仓库
repositories {
        maven {
            url 'http://maven.aliyun.com/nexus/content/repositories/releases/'
        }
    }

引用其他公司的maven库,只需要的maven方法中定义url。

本地依赖

依赖在项目的libs文件夹下的某个jar文件

dependencies {
       implementation files('libs/xxx.jar')
}

依赖在项目的libs文件夹下的全部jar文件

dependencies {
     implementation fileTree(include: ['*.jar'], dir: 'libs')
}
native包(so包)

用c/c++写的library被称为native包(so包),Android插件默认情况下支持native包,只需要要native包放到相应的文件夹中即可。

app
   ├── AndroidManifest.xml
   └── jniLibs
       ├── armeabi
       │   └── nativelib.so
       ├── armeabi-v7a
       │   └── nativelib.so
       ├── mips
       │   └── nativelib.so
       └── x86
           └── nativelib.so
创建和使用依赖工程模块

有两种方式使用一个依赖工程:

include ':app',':模块名'

然后在定义依赖的地方添加

 dependencies {
       implementation project(':模块名')
  }
repositories {
    flatDir {
        dirs 'aars' 
    }
}

依赖所有的arr文件(在aars/libraryname文件夹下的所有aar文件)

 dependencies {
       implementation (name:'libraryname', ext:'aar')
}
依赖配置

Gradle3.4引入新的Java库插件配置

Java库插件的依赖配置

Java Library plugin configurations.PNG

测试依赖配置

test configurations.PNG

注:compile、testCompile、runtime和testRuntime已被弃用。

动态版本(建议不用)
在依赖配置中,version可以使用动态。

dependencies {   
       //22.2版的最新版本
       compile 'com.android.support:support-v4:22.2.+'
       //22版本且其最小版本号是2的最新版本
       compile 'com.android.support:appcompat-v7:22.2+'
       //最新的版本
       compile 'com.android.support:recyclerview-v7:+'
}

不建议使用动态版本,因为动态依赖的最新版本可能会导致程序产生很多问题。

参考资料:

上一篇下一篇

猜你喜欢

热点阅读