Android 项目开发清单

良好的开始是成功的一半,对于一个 Android 项目更是,一个好的项目基础架构可以对项目的后续发展有至关重要的作用。所以我们在项目开发之初,应该花费一些时间去调研、设计符合自己项目的基础架构。而且从项目长远的发展来看,这些时间花的非常值得。

下面就从项目的方方面面出发,介绍一下自己搭建项目时的一些经验。当然个人水平经历有限,自己的分享可能有片面性和不足性,欢迎指正补足。

代码质量保证

项目开发是一个团体活动,每个人都有自己不同的技术风格以及代码风格,但是为了项目后续的可维护性、健壮性,我们需要项目开发过程中,尽早采用统一的编码风格和代码质量检测跟进,防止后续的代码管理变得混乱不堪。下面介绍几个已经被大家广泛采用的代码质量保证工具。

CheckStyle

CheckStyle 是一个帮助开发者严格按照指定的编码规范标准编写代码的一个工具,它能结合 Android Studio 与相应的插件在开发过程中自动检测 Java 编写规范,以减少人工检测代码的成本。也可以使用 Gradle 通过 task 去检测代码是不是符合指定的规范。

具体如何在 AndroidStudio 中使用,可以参考之前的一篇文章使用 CheckStyle 检查代码

FindBugs

FindBugs 这个名字本身已经揭示了它的作用

“FindBugs uses static analysis to inspect Java bytecode for occurrences of bug patterns.”

FindBugs 是一个工具,它能通过静态分析方式扫描 Java 字节码,发现其中的可能出现 bug 的代码,它能发现一些常规的低级的错误,例如一些错误的逻辑操作,也能发现一些比较隐晦的错误。

PMD

PMD 是一个非常强大的工具,它的作用类似 Findbugs,但是它的检测扫描是基于源码的,而且 PMD 不仅仅能检测 Java 语言,还能检测其他语言。PMD 的目标和 Findbugsd 非常的相似,都是通过定义的规则静态分析代码中可能出现的错误,为什么要同时使用 PMD 和 Findbugs呢?由于 Findbugs 和 PMD 的扫描方式不一样,PMD 能发现的一些 Findbugs 发现不了的问题,反之亦然。

PMD 可以发现程序中的无用变量、空的catch块、不必要的对象创建等。

Android Lint

“The Android lint tool is a static code analysis tool that checks your Android project source files for potential bugs and optimization improvements for correctness, security, performance, usability, accessibility, and internationalization.”

正如官网所说,Android Lint 是另一个静态代码分析工具,专门针对 Android 工程。Android Lint 除了对代码扫描,分析潜在问题之外,还能对Android的资源进行检测,无用的资源,错位的dip资源等。同时, AndroidStudio 以及集成了 lint ,你可以很方便的使用。步骤如下。

AndroidStudio -> 菜单 -> Analyze -> Inspect Code

另外,你可以通过 gradle 脚步指定自己的 lint 规则,以及报告生成路径

android {
    lintOptions {
        abortOnError true
         lintConfig file("${project.rootDir}/config/quality/lint/lint.xml")
        // if true, generate an HTML report (with issue explanations, sourcecode, etc)
        htmlReport true
        // optional path to report (default will be lint-results.html in the builddir)
        htmlOutput file("$project.buildDir/reports/lint/lint.html")
    }
}

代码质量保证工具终究只是一些辅助手段,如何在项目开发过程中,保持持续高质量代码的输出更多的要依靠开发者自身对自己的要求,以及团队长期的技术文化建设上。

持续集成

如果是开源项目可以使用 travis 进行持续集成,travis 跟 github 结合的特别好。使用起来也比较简单,如果你的开源项目已经跟 travis 结合成功,你可以使用下面的 bubble 代码为自己的项目加一个 bubble,方便在项目主页查看项目最新的编译状态。

![Build Status](https://travis-ci.org/maoruibin/TranslateApp.svg?branch=master)

效果如下

如果是企业项目,还是自己搭建个持续集成工具比较好玩,嗯,就是 Jenkins。你可以按照 Jenkins 的安装文档在自己公司的内网环境下安装 Jenkins,然后就可以随意配置各种 task 。

另外,前段时间发现另一个国内的持续集成工具也不错,是在线形式的,类似 Travis, 叫做 flow.ci ,比较有意思的是他有一个工作流的东西,比较好玩,而且跟 fir 天然支持。

生产力 / 效率

真实的团队项目开发是一个持续的过程,一个项目的生命周期有长有短,参与的人数有多有少,但即使比较短也可能要持续数月之久,所以一般的项目都需要花费不少时间精力。对于研发来讲,我们可以不关注效率方面的信息,使用最原始的工具、API 通过刀耕火种的方式完成开发,其实 Android 刚流行的时候,我们的开发确实是这样过来的,各方面的工具,开源方案较少。

但是经过 10 年的发展,Android 开发生态已经有了长足的进步和完善,包括开发工具、开源方案都已经非常完善,所以有必要在开发中留意并使用一些已经被其他团队证明可行的方案技术以及一些生产力工具。

下面列举一些对 Android 开发效率有提升的工具以及相关的东东。

AndroidStudio Templete

项目开发过程中,随着开发框架的成熟,总会有一些代码经常重复性的编写,这时,你可以通过使用 AndroidStudio 的 templete 来快速生成代码。如新建 Activity, 现在大项目都会有一个 BaseActivity, 尽管 AS 也提供了 Activity 的模板,但是跟我们项目需要差别很大,所以,这时可以自定义自己项目的模板。

其实模板的适用范围特别大,不仅仅是 Activity 所有一些重复性比较强的模块类代码都可以使用自定义模板,这里的想想空间比较大,结合项目中的一些成熟的开发框架,你可以使用模板去把一些重复性的工作用模板完成。

至于如何自定义模板,网上的文章很多。

参考链接

AndroidStudio 插件

下面列举一些自己常用的 AS 插件。

GsonFormat

首推 GsonFormat, 这个插件我在 2015 年开始使用,简直是神器。尤其是自己已经手工写了很久的实体类后,当时发现这个插件后,欣喜若狂,具体它是干什么的,简单说,就是帮助开发者快速将服务端返回的一个 JSON 实体字符串转化为 Java 实体类的 AS 插件。具体可以查看项目主页。

zzz40500/GsonFormat: 根据Gson库使用的要求,将JSONObject格式的String 解析成实体

ButterKnife

butterknife 是 JW 主导开发的一个 View 注入工具。它使用注解简单明了的替换传统的 findViewById ,还可以简化事件点击的监听等等,更多使用介绍可以看官网或者之前的一篇关于 ButterKnife 的介绍文章。

上面提到的这些用法只是让你提速,但真正意义的效率飞跃是使用它提供的 AS 插件 - ButterKnifer Zelezny,使用他后可以让你的 View 实例化从此自动化,工具化,无需手动码代码。

生产力/效率总结

在开发中,个人非常注重生产力效率。因为你的效率提升意味着你在同样的时间里产出就比别人多,侧面体现了你的价值比别人大,而这仅仅是因为你比别人会使用一个工具,多么神奇的结论。

使用工具后,在节省你工作时间的同时,从另一方面讲也是节省公司的人力成本,所以如果有工具可以提升自己的工作效率,那么我会非常乐意的分享使用它。

另外,对于效率的追求没有终点,你应该花点时间和心思去收集和整理一些效率工具,从而使自己的工作生活更加轻松。其实,如果你关注过一些大公司的话,在大公司里甚至会有一个专门的部门用于研究生成企业内部的生产力效率工具。可想而知,生产力/效率是一个多么重要的话题。

开源框架

网络

  • OkHttp
  • Retrofit

数据库

事件总线

  • EventBus
  • Otto

图片

  • Glide
  • Picasso
  • Freso

网络解析

Log

调试

SharePreference

路由框架

技术文档

在项目开发过程中,必然会涉及到团队成员的沟通,如何更好的沟通?QQ ?微信 ?? 对于一般的非技术性的事务,这些桌面沟通工具确实可以很便捷的完成我们的需求,但是对于我们开发者,大多时候需要沟通一些技术上的问题,对于技术上这种非常严肃的问题,如果只是在群里讨论,粘代码会很容易把答案淹没,无法形成一个长久的记录。

所以,文档就显得特别重要。在实际开发中,不同的人负责的模块不一样,但是不论你负责那个模块,只要你的模块有可能为其他成员提供支持,那么你都应该写一份简单的使用文档,方便其他人在使用时,直接看你的文档就可以解决问题。

不至于其他人在用到你写的模块时,缅甸的同事在项目中搜索你在什么地方使用了相关的 API ,然后大海捞针般的搜到相关的代码后,一边阅读你的代码一遍思考怎么在自己的业务场景中使用。直率点的同事可能不顾你现在是不是忙工作,直接会发消息给你,询问相关 API 的使用,然后你的工作遭到打断,马上指点如何使用自己设计的 API。

然后这样的事情,一遍遍的发生在开发过程中,不同的同事遇到同样的问题,每次都是直接去询问当事人。

这是一种非常低效的开发模式。尤其是那种大项目,模块可能很多,这种问题也会很多。

所以,如果大家在开发自己的模块时,使用文档把一些技术要点简单罗列出来,然后把文档放在一个统一的地方,大家以后有问题,直接找文档,如果文档还没解决问题,再去找负责人,是不是会节省很多沟通成本。

关于文档,这里不仅仅是技术文档,开发中的文档有很多类型,下面列举一些文档。

技术说明文档

如上所述,就是典型的技术模块说明文档,应该包括简单明了使用说明以及一些特殊情况处理。

规范说明类文档

比如代码中的命名规范,提交规范等。下面是 GitHub 上自己的一些开源文档。

工具使用类文档

比如项目中一些开发工具使用说明。

常用信息检索类文档

比如项目中的全局属性类介绍。

其他类

参考链接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,926评论 25 707
  • 1 背景 一个项目开发必然会涉及团队协作,而工程质量就需要团队去保证。一般我们期望的代码:无潜在风险、无重复逻辑、...
    zyl06阅读 3,214评论 5 16
  • 太长了,还是转载吧...今天在看博客的时候,无意中发现了@Trinea在GitHub上的一个项目Android开源...
    庞哈哈哈12138阅读 20,168评论 3 283
  • 有那么一群人,是精分。他们或许封闭,心理添上了阴影。有的一生都处于灰白空间,有的努力为人生添上色彩。在一个思维空间...
    美意_cb13阅读 409评论 0 0
  • 回家喽! 现在的人对过年回家的感觉没有老一辈那么的强烈了,回家…回家… 过年回家不是为了吃吃喝喝玩玩,是为了不让爱...
    cca8065f6f69阅读 266评论 0 1