开发安卓Apps,我所努力学习到的三十多条宝贵经验

jingjingha 9年前
   <p>网上阅读时猎取到的一篇外国工程师的文章,作者结合自己在安卓领域的摸爬滚打经历总结了三十多条宝贵经验,非常值得参考学习,故翻译记录于此,并作了一些补充说明,帮助阅读理解。</p>    <p>学习领域有两种人,一种是自身刻苦钻研一步一步摸索的人,一种是采取捷径获取别人经验的人。下面是我一路学到的东西,和你分享:</p>    <ol>     <li> <p>添加使用第三方类库前,请再三思考,真的很重要;(未来一些未知的错误也许就发生在这些类库中,关于第三方类库的选择,参考文章: <a href="/misc/goto?guid=4959723362231963365" rel="nofollow,noindex">stormzhang-如何正确使用开源项目?</a> )</p> </li>     <li> <p>用户看不到的地方,就不要去画它;(避免过度绘制,参考文章: <a href="/misc/goto?guid=4959665557293930631" rel="nofollow,noindex">Optimizing Layouts in Android – Reducing Overdraw</a> )</p> </li>     <li> <p>除非真的需要,否则不要使用数据库;</p> </li>     <li> <p>应用中65K的方法数很快就能达到,我的意思是真的很快!不过 <a href="/misc/goto?guid=4959628481821689111" rel="nofollow,noindex">multidexing</a> 也许能帮到你;(最近刚总结过一篇: <a href="/misc/goto?guid=4959723362375754487" rel="nofollow,noindex">Android 突破64K方法数的限制</a> )</p> </li>     <li> <p><a href="/misc/goto?guid=4958865750209621132" rel="nofollow,noindex">RxJava</a> 绝对是 AsyncTasks 等绝大多数类最好的替代品;(参考文章: <a href="/misc/goto?guid=4959723362484312036" rel="nofollow,noindex">Party tricks with RxJava, RxAndroid & Retrolambda</a> )</p> </li>     <li> <p><a href="/misc/goto?guid=4958837204152834453" rel="nofollow,noindex">Retrofit</a> 是最优秀的网络框架;(没有之一)</p> </li>     <li> <p>使用 <a href="/misc/goto?guid=4959665557546823246" rel="nofollow,noindex">Retrolambda</a> 缩减你的代码;</p> </li>     <li> <p>感受 RxJava 与 Retrofit 和 Retrolambda 一起使用的魅力;(参考文章:参考文章: <a href="/misc/goto?guid=4959723362484312036" rel="nofollow,noindex">Party tricks with RxJava, RxAndroid & Retrolambda</a> )</p> </li>     <li> <p>我使用 EventBus ,它很强大,但我不会过度使用,因为它会使代码库会变得很杂乱无章;</p> </li>     <li> <p>根据应用功能分包,而不是所属类别;(项目目录结构划分,参考文章: <a href="/misc/goto?guid=4959723362642074741" rel="nofollow,noindex">Package by features, not layers</a> )</p> </li>     <li> <p>移除Application线程里的一切代码;(避免拖慢应用的初始化和启动速度)</p> </li>     <li> <p>使用 <a href="/misc/goto?guid=4959665557748522488" rel="nofollow,noindex">lint</a> 优化布局,以便你能一眼识别出冗余的视图并移除;</p> </li>     <li> <p>如果你使用 gralde ,想尽一切办法加快编译速度;(参考文章: <a href="/misc/goto?guid=4959723362743647818" rel="nofollow,noindex">How I save 5h/week on Gradle builds</a> )</p> </li>     <li> <p>使用 <a href="/misc/goto?guid=4959665557833796699" rel="nofollow,noindex">Profile report</a> 查看编译时间到底是在什么地方耗费的;</p> </li>     <li> <p>尽量使用众所周知的成熟架构体系;(参考文章: <a href="/misc/goto?guid=4959645682790644451" rel="nofollow,noindex">Architecting Android…The evolution</a> )</p> </li>     <li> <p>测试消耗时间,但是一旦你掌握了测试的窍门就会发现,它比没有经过测试的代码更快更稳妥;(参考地址: <a href="/misc/goto?guid=4959723362888603373" rel="nofollow,noindex">http://stackoverflow.com/questions/67299/is-unit-testing-worth-the-effort/67500#67500</a></p> </li>     <li> <p>使用 依赖注入 使你的应用更加模块化,并且更容易测试;(参考文章: <a href="/misc/goto?guid=4959632560345740383" rel="nofollow,noindex">Tasting Dagger 2 on Android</a> )</p> </li>     <li> <p>关注 <a href="/misc/goto?guid=4958973724258090573" rel="nofollow,noindex">Fragmened Podcast</a> 对你大有帮助;(Fragmented,一个专属安卓开发者的播客网站)</p> </li>     <li> <p>永远不要使用私人邮箱作为安卓市场的发布者账号;(主要是Google Play,案例参考: <a href="/misc/goto?guid=4959665558092007438" rel="nofollow,noindex">https://www.reddit.com/r/Android/comments/2hywu9/google_play_only_one_strike_is_needed_to_ruin_you/</a> )</p> </li>     <li> <p>坚持使用合适的输入类型;(针对输入框,参考链接: <a href="/misc/goto?guid=4959723363056685490" rel="nofollow,noindex">Specifying the Input Method Type</a> )</p> </li>     <li> <p>学会借助分析学寻找通用模式和孤立问题;(设计模式,封装等)</p> </li>     <li> <p>保持学习最新开源类库,并借助 dryrun 工具测试开源类库;( Android Arsenal ,一个搜索整合Android开源类库的网站)</p> </li>     <li> <p>Service服务应该做它们需要做的事情,并且尽可能快地终止;</p> </li>     <li> <p>使用 Account Manager 提示用户名和邮箱地址;</p> </li>     <li> <p>使用CI(持续集成)编译构建测试版和发布版应用;</p> </li>     <li> <p>不要运行你自己的 CI server ,防止SSL攻击而造成的磁盘空间、安全问题、服务更新都需要维持server,这是一件耗费时间的任务。使用 circleci 、 travis 和 shippable ,相比而言,性价比更高,更可靠;</p> </li>     <li> <p>使用 gradle-play-publisher 自动部署上传Apk文件等信息到应用商店;</p> </li>     <li> <p>如果一个library比较大,而你只是用到其中的一小部分功能,那么你就应该寻找一个更小的替代品;(比如可以借助 proguard 工具)</p> </li>     <li> <p>不要大量使用超出你实际需要的依赖库。特别是当这些依赖库不是经常在变时,我们就要考虑到,这些类库从头编译(CI Builds就是一个很好的例子)或者检查之前编译好的独立类库是否需要更新所花费的时间相比简单地加载jar或者aar这样的二进制文件,高达四倍之多;</p> </li>     <li> <p>开始考虑使用SVG代替PNG格式的图片;(参考地址: <a href="/misc/goto?guid=4959665558448000739" rel="nofollow,noindex">Add Multi-Density Vector Graphics</a> )</p> </li>     <li> <p>封装抽象化library的使用,这样当你需要使用新的library替代旧library时就会变得很容易;</p> </li>     <li> <p>监听网络连接变化和连接类型(Wifi状态下数据更新更频繁?);</p> </li>     <li> <p>监听电源和电池电量变化(充电时数据更新更频繁?电池电量不足时暂停更新?);</p> </li>     <li> <p>展现给用户的UI就像一个笑话,如果你不得不解释一下的话,它就不是一个好笑话;</p> </li>     <li> <p>性能测试很重要:Coding实现慢,但要正确,然后验证优化,这不会影响任何测试内容。</p> </li>    </ol>    <p> </p>    <p>来自:http://yifeng.studio/2016/10/27/android-develop-30-things-that-experience-made-me-learn-the-hard-way/</p>    <p> </p>