在实际的android项目开发过程中,我们一般都会用一些现有的第三方库来实现我们的需求,避免重复造轮子。普遍使用到的,例如:网络请求库、图片处理库、界面UI库(自定义View、动画效果等)、各种第三方SDK库(聊天、推送等)。笔者早期接触android使用eclipse开发时,当时对这些库的管理方式为:如果能jar包,则将jar包拷贝到libs目录下;还有一些源码库,则以library的方式倒入到工程中,调试、 修改、编译、发布。早期的这种库管理方式存在的一个严重问题是:无法自动跟踪版本、不能自动同步library的更新。现在一般都使用android studio,结合git,maven来开发android项目。本文通过一些实际场景,对as + git + maven的工作方式、流程进行简单介绍,相信看完后,读者会对android项目中包管理机制有一个总体上清晰的认识。

1 发现githuab上有个好用的库,该如何使用?

直接按照文档提示,在build.gradle中添加依赖即可。背后到底发生了什么,使我们只需要加一句话,就能使用库?

通过Android studio创建默认项目后,在项目根目录下的build.gradle中有一段代码:

allprojects {
repositories {
jcenter()
}
}

这段代码,相当于告诉gradle,如果碰到依赖的库需要下载,去jcenter找。jcenter又是什么,他相当于一个所有公开的库的集合(仓库)。jcenter中的库,以maven包的方式来管理。其实背后的事情是:github中库的作者自己生成了一份代码对应的maven包,并且将maven包上传到了jcenter仓库中,所以gradle最后才能从jcenter中下载到maven包。本文不对jcenter进行详细介绍,只需要知道他是一个存放library(库)的repository(仓库)即可。

2 项目进行一段时候后,代码会变大庞大臃肿,这时候,可以将一些相对独立、复用性高的模块独立出来封装成一个库,简化项目逻辑代码。假设我们将一个模块独立了出来做成了library。这个library不光我自己使用,其它的开发者也要使用,怎么做呢,肯定不能把代码拷贝一份。这时候,我们可以用gradle的maven插件,将library打包成一个maven包。其它开发者可以只拷贝maven包,而不用拷贝源代码。Android studio项目,如何使用本地的maven包?只要能告诉gradle遇到依赖库的时候,去某个路径下找即可。方法是,在module的build.gradle中配置:

repositories {
maven { url "file:///path/to/maven" }
}

最后在dependencies中添加compile依赖即可。

3 让每个开发者每次都拷贝一份maven包,也不科学。如何改进?项目代码,我们一般用git来进行管理。同理,library生成的maven包,我们同样可以用git来管理。主项目通过git submodule的方式来管理library生成的maven包的git仓库。这样以来,工作流程是:

库的修改者:

  1. 在本地修改library,调试通过后,提交代码到git
  2. 通过gradle maven 插件,生成maven包,将maven包提交到另外一个git仓库(管理maven包的仓库)

库的使用者:

  1. 通过git submodule update,更新submodule git仓库(管理maven包的仓库)
  2. 根据maven包中的groupId、artifactId、version信息,修改build.gradle中的dependencies依赖
  3. gradle同步完成后,即可使用最新的库代码来开发主项目
  4. 开发完后,想主项目的git仓库提交代码

4 如果library没有隐私可以公开,那我们可以像github上的一些库一样,生成maven包后,将maven包发布到jcenter/maven。这样一来,就只需要在主项目module的build.gradle中配置dependencies compile依赖即可。

总结:

  1. android项目中依赖的库,本质上是maven包
  2. maven包可以放在公开的jcenter仓库中,也可以放在本地,或者其它某个服务器上
  3. 如果是在jcenter中,我们无需配置仓库地址,项目根目录下默认生成的build.gradle已经帮我们配置好了
  4. 如果是在其它地方,本地目录,或者其它某个服务器上,需要在build.gradle中用repositories来配置仓库的具体路径,这样,当我们在dependencies compile配置了依赖库的时候,gradle才知道从哪里去下载。

Android项目依赖库管理方式简介的更多相关文章

  1. Android项目-高考作文功能简介(一)

    前言 :  开发安卓也已2年多了近3年了, 在自己刚入行的时候就有自己独立开发一个App的想法. 后来自己做了<<高考作文>>这一App. 后面续续断断的维护者. 也因为功能简 ...

  2. Jenkins构建Android项目持续集成之findbugs的使用

    Findbugs简介 关于findbugs的介绍,可以自行百度下,这里贴下百度百科的介绍.findbugs是一个静态分析工具,它检查类或者 JAR 文件,将字节码与一组缺陷模式进行对比以发现可能的问题 ...

  3. 使用Jenkins进行android项目的自动构建(2)

    Maven and POM 1. 什么是Maven? 官方的解释是: http://maven.apache.org/guides/getting-started/index.html#What_is ...

  4. iOS开发之通过Framework建立项目依赖

    https://www.jianshu.com/p/d146db167bf3 项目开发时经常会遇到个别模块想打包成framework的情况,传统的打包方式太繁琐,反复测试时很麻烦,不如一个项目管理来得 ...

  5. Android 查看项目依赖树的四种方式

    Android 查看项目依赖树的四种方式: 方式一: ./gradlew 模块名:dependencies //查看单独模块的依赖 ./gradlew :app:dependencies --conf ...

  6. 使用Roboguice依赖注入规划Android项目

    前言 好久没写博客了,罪过啊-记事本里累积了不少东西,整理整理放上来. 关于依赖注入 Dependency Injection( 依赖注入)可以很好的帮助我们分离模块,降低耦合.提高可测试性.(PS: ...

  7. Android注解使用之Dagger2实现项目依赖关系解耦

    前言: 最近牵头发起公司app的重构工作,如何通过重构让项目的耦合降低.开发效率提高,一直是我努力的方向,今天来学习一下一个注解框架Dagger2,然后看看如何使用它来降低项目的耦合. Dagger2 ...

  8. Android项目实战(三十三):AS下获取获取依赖三方的jar文件、aar 转 jar

    使用 Android studio 开发项目中,有几种引用三方代码的方式:jar 包 ,类库 ,gradle.build 的compile依赖. 大家会发现github上不少的项目只提供compile ...

  9. Android Studio Jar、so、library项目依赖

    Eclipse跟AS的不同 从Eclipse到AS不要带着在Eclipse中的主观色彩去在AS中使用,从项目的构成到构建是不同的,下面列举在Eclipse和AS中的一些概念的区别: WorkSpace ...

随机推荐

  1. Unity5-ABSystem(四):AssetBundle依赖

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/lodypig/article/detai ...

  2. 建议收藏:.net core 使用导入导出Excel详细案例,精心整理源码已更新至开源模板

    还记得刚曾经因为导入导出不会做而发愁的自己吗?我见过自己前同事因为一个导出改了好几天,然后我们发现虽然有开源的库但是用起来却不得心应手,主要是因为百度使用方案的时候很多方案并不能解决问题. 尤其是尝试 ...

  3. Zabbix_agent 三 被动模式的配置

    zabbix一共有三种监控模式分别默认是被动模式,由agent端收集数据,server去请求然后获取agent的数据. 还有就是主动模式,由agent收集数据并定时发送到server端,则就是被动模式 ...

  4. [考试反思]0822NOIP模拟测试29:延续

    想保持优秀很困难 但是想持续垫底却很简单 但是你不想垫底的话持续垫底也很容易... 分AB卷,A卷共15人. skyh,tdcp,kx155,B哥145... 我:35,倒数第一. 板子专题,爆零快乐 ...

  5. Python - selenium自动化-Chrome(headless)

    什么是 Headless Chrome Headless Chrome 是 Chrome 浏览器的无界面形态,可以在不打开浏览器的前提下,使用所有 Chrome 支持的特性运行你的程序.相比于现代浏览 ...

  6. 查看redis占用内存大小的方法

    查看redis占用内存大小的方法 <pre>redis-cli auth 密码info</pre><pre># Memory used_memory:1349009 ...

  7. python 基础之 模块

    Python 基础之模块 一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 就是一个python文件中定义好了类和方法,实现了一些功能,可以被别的python文 ...

  8. [UWP]使用Win2D的BorderEffect实现图片的平铺功能

    1. WPF有,而UWP没有的图片平铺功能 在WPF中只要将ImageSource的TileMode属性设置为Tile即可实现图片的平铺,具体可见WPF的这些文档: ImageBrush 类 (Sys ...

  9. Ubuntu18.04.3 LTS初体验

    安装系统 想来虚拟机安装太慢,正好有一台旧电脑,干脆整个乌班图系统. 启动盘工具:UltraISO,老牌工具了. 上官网下载ISO镜像文件: https://cn.ubuntu.com/downloa ...

  10. C++中对C的扩展学习新增语法——强制类型转换

    类型转换:主要进行指针类型转换,因为在C++中,不同类型指针不允许隐式转换,任何一个程序中如果出现了大量的类型转换,说明该程序不是太好的程序. 注意事项: 不同类型指针不允许隐式转换: void* 类 ...