本文转自

http://mp.weixin.qq.com/s?__biz=MzAwNDY1ODY2OQ==&mid=400785752&idx=1&sn=e1c166e7fad0892811c9ca9bca6d1540&3rd=MzA3MDU4NTYzMw==&scene=6#rd&utm_source=tuicool&utm_medium=referral

编者的话:simsun在2013年从手Q转岗到微信,在此非常感谢他对微信做出的贡献。在我看来,sim是一个活生生的全栈工程师,从硬件、后台到iOS、Android样样精通。同时sim非常崇尚开源,以开放的心态去做事,是一个节操满满的新时代码农。尽管他为了个人家庭与事业离开了微信这个大家庭,但在这里我再次祝福他在新的舞台能取得更大的成功。
simsun在短短两个月内参与了"走起"app从后台、iOS、Android全程的设计与开发,最终完成上线,与微信从0到1的“创业”经历有很多相同之处。在下面我们听听他对提升开发效率的一些想法。

开篇先友情提示一下,此篇文章所谈论的部分技术点与微信关联不大,如有描述不准确的地方,也欢迎大家指出与讨论。笔者去年从微信团队“毕业”,变成一个创业码农,期间也踩过一些坑,这里与大家分享一些我个人的经验。

微信的整体氛围很像创业公司,快速、高效。但微信团队对技术的挖掘还是很深的,这一点在创业公司比较难做到。创业公司更追求快速、稳定的做出功能,完成迭代。

下面给大家介绍一点我个人觉得很大的提高了我的开发效率的工具。

App架构

RxJava

首先给大家安利 ReactiveX ,其中Android的核心实现为RxJava。

为了App不卡顿,我们会把所有耗时的操作(比如:网络访问、文件访问)放到Worker Thread中。但是Android本身的AsyncTask的设计个人觉得设计的十分糟糕,不但写出来的代码冗长,而且稍微复杂一些的多流操作就会写的完全无法维护(这里可以用Java本身的线程模式来实现)。而且肆意的开线程也会造成App的卡顿。这里本身最初的想法就是需要一个线程池,以Promise的方式对外提供接口。原先试用过facebook的开源方案 Bolts-Android ,这个库是parse的开源方案。后来有iOS的同事推荐Reactive的方案,于是就走上了Rx脑残粉的不归路。

这里微信也有类似方案,通过将所有的线程和Handler使用接口收敛,以监控和控制无节操的开线程、卡顿为主要目标。而Rx的方案以帮助我们用少量的code,清晰的实现复杂的时序逻辑为主。

首先Rx会大大减少你的代码量,这一点对“懒惰”的我们十分重要。 下面举2个平时开发都会遇到的问题来举例:

1. 搜索界面

我们需要在用户输入完毕后第一时间显示搜索结果,由于这个需要请求后台,我们又不想用户每次输入的时候都去后台请求。并且总需要显示当前最新输入内容的结果,不能因为网络的原因产生乱序的结果。

RxTextView.textChanges(searchEditText).compose(this.bindToLifecycle()).debounce(300, TimeUnit.MILLISECONDS).switchMap(SearchService::searchFeed).subscribe(feeds -> updateUI(),throwable -> RxUtil.handleError(throwable, activity));

几句简单明了的代码,满足上述的需求,而且看起来十分明了简单。其中 .compose.(this.bindToLifecycle()) 是为了防止内存泄露, .debounce(300, TimeUnit.MILLISECONDS) 是表示间隔为300毫秒,使用switchMap是会停止之前发出的请求,防止脏数据重入。 由于Android并不支持Java 8,所以我们需要Retrolambda,来支持lambda表达式。

2. 防止多次点击重入

RxView.clickEvents(button).throttleFirst(300, TimeUnit.MILLISECONDS).subscribe(this::onButtonClick);

MVP & MVVM

关于MVP&MVVM我一直是拒绝的,因为一开始的几个Screen我是用硬套MVP&MVVM的模式来做的,虽然activity的代码十分简单,但是View和ViewModel都会写一些晦涩、重复的逻辑来保证数据绑定,这不符合D.R.Y.。后来发现google官方有一个data-binding( http://developer.android.com/tools/data-binding/guide.html )的实现,感觉实现和prism十分类似,已经在最新的迭代中开始使用data-binding来实现MVVM,具体可以参考一个第三方例子( https://github.com/ivacf/archi )。

如何优雅的偷懒

REST Client

关于REST API是一件几乎纯体力活,这里应当使用代码生成工具来帮助我们完成繁琐的工作。如果你的App像微信一样追求极致的性能和极少流量耗费,这里可以使用protocal buffer。这个有一个坑,就是PB原生的生成器生成的方法数非常多,会造成Android方法数64K的问题。微信里的pb生成器做了比较多的优化,来减少方法数问题。对于创业者来说,可以关注Square开源的wire。

笔者的APP使用了更容易调试的JSON。其中我们可以定义JSON Schema来描述协议,后台与客户端都可以拿这个schema来生成自己的Model和验证协议数据。Android中可以jsonschema2pojo( https://github.com/joelittlejohn/jsonschema2pojo )来生成自己的Model代码,并且可以生成Parcelable代码(PS:这一部分可能还存在隐藏BUG,如果你在使用过程中有什么问题可以提issue或者直接联系笔者)。

关于REST API还有一个杀手级的库 Retrofit 。Retrofit可以完美配合jackson+Rxjava来实现一个基于ReactiveX的REST Client。

@GET("/v2/feeds/search")
Observable<List<FeedDetail>> searchFeeds(@Query("query") String query,@Query("tag") String tag,@Query("page") int page
);

声明十分简单明了,具体可以去 retrofit 的官网了解更多。

Image Loader

整体APP的架构完成后,图片库也是对于APP十分重要的。笔者刚入职的时候,就是在照着google tutorial上的图片加载的例子写过一个ImageLoader,深深感到做一个高效的图片库还是有很大难度的。还好现在各路大神给了我们很多选择,下面3款笔者认为是可以选择的option:

1. Picasso (https://github.com/square/picasso)

2. Glide (https://github.com/bumptech/glide)

3. Fresco

(https://github.com/facebook/fresco)

其中 Picasso 和 Glide 的接口十分接近,但是benckmark下来 Glide 的性能更好一些,并且支持更多格式的图片,我们现在使用的的是 Glide ,而 Fresco 的功能是这3个库中最强大的,且支持 PJPG 。但是他需要替换你的View,并且接口设计的不如上述2个库。笔者在3个多月以前用 Fresco 的时候,他在加载多张图片的时候偶尔会有显示不出的情况,不确定现在是否修复。

微信内的ImageLoader针对自身的一些特有业务做了比较多定制化的工作,特别对内存做了比较深入的优化与监控,其他大体功能上相差不大。

ButterKnife

Jake Wharton是个非常高产的大神,诸多开源库都是他主导的(RxAndroid也是他主要在主导)。 ButterKnife 可以帮助你少写很多重复的code。配合IDEA的插件可以不用写很多繁琐的 findviewByid 的搬砖代码。

质量保证

监控数据对于App来讲也十分重要,这方面虽然不体现任何功能,Growth Hacker和开发都需要经常关注。微信的监控与上报可以说做的非常强大,但是对于创业者来说,无法花那么多时间与精力在这些方面,还好有一些第三方提供一些类似的相关服务。笔者现在在用的有一下几款产品:

1. fabric (https://get.fabric.io/)

2. umeng (http://umeng.com)

3. splunk

(http://www.splunk.com)

fabric和umeng的功能有很大的重叠,fabric是twitter旗下的数据上报和分析系统,笔者这里使用了他的crash报上,做的十分强大,给App的质量提供了保证。splunk是一款服务端的log分析系统,有了他的支持客户端可以减少需要无谓的事件上报。

另外, DebugDrawer 也值得推荐,可以帮你快速的在debug版本分析、诊断问题。

微信内的质量数据监控与上报则因为数据保密方面的考虑使用了自研平台。有实时的分钟级别的上报与报警平台,崩溃上报与分析,以及卡顿、内存、SQL等各种精细化监控模块。

最佳实践

关于最佳实践当然见仁见智,不过笔者还是推荐一些比较成熟的方案 android-best-practices ,这个建议精读一下,里面的每一条都是别人踩过的坑总结来的,十分有价值。

微信内部的开发流程基本会遵循git-flow ( https://github.com/nvie/gitflow ) ,即单feature单branch,功能完成合入稳定分支。微信在git实践上因为大量使用并行开发,存在多个并行的release分支。笔者在创业时依然延续了这个规则,虽然每个repo只有1-2个人同时提交代码,但是这么做可以快速应对需求的变更,并保证commit的规整性。虽然在commit时会多花5秒钟来操作一下,但是这样留下的是一个规整的历史,方便后续review和bisect。 另外TJ开发的git-extras( https://github.com/tj/git-extras )会有很多对github友好的命令,会让你每天少打很多无脑的命令,以下 是git-flow官网的流程,建议大家尽量按照其流程进行迭代开发。

另外关于代码格式,也没有官方统一的方案,笔者这里推荐使用Square的java-code-styles( https://github.com/square/java-code-styles ),也可以自己fork做相应的修改。

另外高压的开发很容易让程序员感觉到焦躁,这里我们还是要引入一些趣味的奖惩,笔者这里沿袭微信的“饼干法则”。对于很傻瓜的Bug我们要对Bug的引入者进行一点小小的惩罚,比如可以让他给大家买咖啡或者甜筒。而对于写出优雅且鲁棒的代码,我们可以给他加一个鸡腿。

另外强烈push设计的同学使用Sketch,这样不仅可以解放设计的同学在无尽的切图中,也可以让自己节约更多的时间。

总结

感谢大家可以看完笔者的碎碎念,也感谢微信让笔者从一个青涩的学生成长了还算合格的程序员。笔者离职一年,感觉创业和做freelancer有很多相似的地方,有大量灵活的时间,你需要学习如何去掌握你的时间,毕竟工作只是生活的一部分,你需要合理的分配时间。所以你的代码要尽可能的少些,即能自动生成的就用脚本来做,能抽象的就不重复去写,可以给自己节约更多的时间去玩耍。

编者后记: sim离开微信团队的这一年中,我们完成了平台期发展的思路转换,关注的重点从原来的功能开发迭代开始转向更基础化的平台研发能力。开源和分布式开发的思想也在团队内部兴起,微信内使用的开发工具、组件、流程也陆续诞生了一批内部开源项目。从内到外,相信在不远的未来,大家就可以在github上看到它们。

参考文章

  1. ReactiveX ( http://reactivex.io/ )

  2. Retrofit ( https://github.com/square/retrofit )

  3. ButterKnife ( https://github.com/JakeWharton )

  4. android-best-practices ( https://github.com/futurice/android-best-practices )

  5. RxJava ( https://github.com/ReactiveX/RxJava )

  6. RxJava入门教程 ( http://blog.danlew.net/2014/09/15/grokking-rxjava-part-1/) )

  7. android-application-architecture ( https://medium.com/ribot-labs/approaching-android-with-mvvm-8ceec02d5442#.suutwto9a )

  8. android-application-architecture ( https://medium.com/ribot-labs/android-application-architecture-8b6e34acda65#.6qmzrqtdn )

  9. Improving UX with RxJava ( https://medium.com/@diolor/improving-ux-with-rxjava-4440a13b157f#.21alo61m9 )

  10. 给 Android 开发者的 RxJava 详解 ( http://gank.io/post/560e15be2dca930e00da1083#toc_10 )

  11. DebugDrawer ( https://github.com/palaima/DebugDrawer )

给创业码农的话--如何提升开发效率相关推荐

  1. 提升开发效率的十个工具

    Git 之前也有过不少版本控制的工具.有好的,也有糟糕的.不过它们都或多或少地误入歧途了. 这时候Git出现了.一旦你用上了这个神奇的工具,很难相像你还会碰到比它更好的了. 还没用过Git?试一下吧. ...

  2. 提升开发效率N倍的20+命令行神器!(附 demo)

    点击上方蓝色字体,关注我 -- 一个在阿里云打工的清华学渣! 图 by:石头@青海湖 关于作者:程序猿石头(ID: tangleithu),现任阿里巴巴技术专家,清华学渣,前大疆后端 Leader.以 ...

  3. 深度解读Microsoft Build 2020:提升开发效率,优化开发环境

    Microsoft Build 2020 在众多新产品与技术发布中圆满落幕 但身为开发技术人深知 技术世界的更迭.求索却从未止步 唯有不断提升自身技能栈创新 方能从技术浮沉中获得更多养分 让技术予力世 ...

  4. 猿创征文|后端开发工程师提升开发效率神器推荐

    简介 对于现在的后端工程师来说,并不仅仅局限于编写代码和解决bug,这两个要素了.如果你目前还只是忙碌的写代码和改bug的话,那要深度思考一下,我为什么日复一日的写这些重复代码?这样有何意义?或者说, ...

  5. 【java】提升开发效率的17个轮子

    提升开发效率的17个轮子 前言 1.Collections 1.1.排序 1.2.获取最大值.最小值 1.3.线程转换安全集合 1.4.返回空集合 1.5.二分查找 1.6.转换成不可修改集合 2.C ...

  6. VueUse——一个提升开发效率的Vue3工具库,让你早早下班

    VueUse--一个大大提升开发效率的Vue3工具库,让你早下班 关注微信公众号"前端大侦探"了解更多精彩内容! 前言 VueUse是一个基于 Composition API 实现 ...

  7. Python学习笔记:Day13 提升开发效率

    前言 最近在学习深度学习,已经跑出了几个模型,但Pyhton的基础不够扎实,因此,开始补习Python了,大家都推荐廖雪峰的课程,因此,开始了学习,但光学有没有用,还要和大家讨论一下,因此,写下这些帖 ...

  8. order by 影响效率么_提升开发效率N倍的20+命令行神器

    图 by:石头@青海湖 关于作者:程序猿石头(ID: tangleithu),现任阿里巴巴技术专家,清华学渣,前大疆后端 Leader.以每篇文章都让人有收获为目的,欢迎关注,交流和指导! 背景 本文 ...

  9. atitit.提升开发效率---mda 软件开发方式的革命

    atitit.提升开发效率---mda 软件开发方式的革命 1. 软件开发方式的革命开发工具的抽象层次将再次提升 1 2. 应用框架和其实现相分离 2 3. 目前的问题模型和代码不同步 2 4. MD ...

  10. atitit.提升开发效率---使用server控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比較...

    atitit.提升开发效率---使用server控件生命周期  asp.net 11个阶段  java jsf 的6个阶段比較 例如以下列举了server控件生命周期所要经历的11个阶段. (1)初始 ...

最新文章

  1. python去重复行_python去除文件中重复的行实例
  2. 程序员因中年危机从北京回老家事业单位:工资从60万爆降到6万
  3. (五)磁盘存储空间的管理
  4. 《模拟信息转换器(AIC)的实现技术研究》读书笔记
  5. Netty 入门示例
  6. java反向注入_java 控制反转和依赖注入的理解
  7. 数据结构二之线段树Ⅰ——Count Color,Hotel,Transformation,Tree Generator™
  8. 如何将Eclipse中的开源项目使用到Android Studio中
  9. UDK控制台命令概览
  10. 《深度学习笔记》——防止梯度消失的学习笔记
  11. 关于GIT的万年坑你还在踩吗?答应我别傻了
  12. ADO.NET 3.5 同SQL 2008的新的存储过程保存方式
  13. 使用 Apache FOP 2.3 + docbook-xsl-ns-1.79.1 转换 Docbook 5.1 格式的 XML 文档成 PDF/RTF 文件
  14. Docker 删除image
  15. 基于单片机的多功能数字时钟设计
  16. Ubuntu挂载nfs
  17. revit2016族管理:如何设置轮廓族来自动分类呢?
  18. 分数求和、数9的个数、乘法口诀表
  19. 达芬奇17调色软件支持m1
  20. 为什么我不敢发布C# EXE程序出去

热门文章

  1. Java多线程的简介
  2. 微信开发 自动转发朋友圈 自动添加好友等等
  3. 苹果雪豹操作系统正式版_苹果为旧机型发布iOS 12.4.2;macOS 10.14.6发布了,Catalina还远吗?...
  4. python msp430_MSP430
  5. 关于我玩单片机学习路线(个人总结)
  6. 数字技术加持 华为云为测绘地理信息产业夯实“云底座”
  7. 小爱同学脱离局域网远程控制开关?
  8. 20190408-相速度和群速度、傅里叶变换与波动方程的色散关系、介电常数与电导、介电函数与折射率、散度定理、电子迁移率、电磁波波动方程、自由电子气的介电函数
  9. 人工智能粒子群优化和群智能
  10. 基于node.js的网页聊天系统设计与实现