2018-07月末总结

1.修改一个组合控件使其成为ViewStub的加载形式

项目进入维护期以后,需要对项目中积累的问题就行优化。在当前的项目中,几乎每一个Fragment、Activity。在进行网络访问的时候,都有异常或者边界的情况。所有在对应的Layout中,我们项目中的代码,都放了一个组合控件:NoNetWorkLayout。名字起的是有点问题,大概主要是针对在网络异常或着数据返回错误时展示给用户的界面。相应的代码就是控制这个layout和content_layout之间的Visibility。考虑NoNetWorkLayout并不是必定有展示需求。所以需要用ViewStub的形式进行优化。不过这个NoNetworkLayout已经深入到各个页面。如果去每一个页面做替换。然后ViewStub.inflate。然后在操作inflate的真实View,那要改动的布局和页面很多,而且这代码重复量比较大。不过好在ViewStub这个类比较简单。所以只需要改动它的实现到NoNetWorkLayout中就可以实现占位,延迟填充。

以ViewStub形式的占位控件

一些额外的问题:其实这个形式的修改,也是针对当前已经进展到这个情况的view的修补。在项目中我看到有不同的developer,会因为NoNetWorkLayout的layout不太合适,又重新拷贝代码,然后设置新的layout_id。继续在自己的代码中引用。其实占位View一般都不会有太复杂的逻辑,控制其修改。所以留一个setLayoutResId的方法,就能完成展示不同的占位功能。如果在UI方面也能提供统一的视觉,那么完全不需要去每个layout占位,完全可以在基类中,延迟new这个layout完成全局的异常 边界 误操作的View处理。


2.Background中Activity被回收

有用户反馈bug,在订单Preview页面,进行优惠券选择后,网络提示异常,ProductList为null。根据BI系统的打点采集,看到用户在从选择优惠券页面返回后。preview页面,急速的进行了两次,订单状态的刷新。正常情况下,只会有一次,就是携带优惠券信息的刷新。考虑两次请求间隔大概20ms,不太可能是用户触发两次信息变化,那么就是自然流程。再结合有一个productsList为null。那就是有数据丢失了。定位到在选在优惠券的page,preView的页面被回收。随后进入重建流程后,分别在onCreate的initData和onActivityResult中有两次数据请求。复现此问题可以使用开发者模式中的 不保留后台活动。随后就是一次数据保存与恢复的过程。其实这个只要定位到这个问题后,就没啥难度了。不过后续的修改有丶难。

ps:记录下activity的生命周期流程。按照重建 + onActivityResult

onCreate onStart(onRestart)  onRestore onActivityResult onResume onPause onSaveInstance onPauce onDestory(onCreate和onRestore中的bundle都有save的数据)

首先就是,要规避重建时onCreate和onActivityResult 两个方法同时请求网络。并且不能影响正常进入的流程。大多数时候Activity没有销毁(其实在数据恢复后,这两个接口就算请求两次,问题也不大。不过这完全是有侥幸的成分,毕竟onCreate的请求总是会比onActivityResult的先返回,前者会被覆盖。不过这样很不OK啊。)

其次是这个PreView的activity,可能是前期开发太快,没有分离业务和UI。所以有2300行代码,2300这个不重要,重要的是,这2000行代码在历代版本中已经跑的飞起而且从来没翻车。但是这个preview要承载的东西太多了。比如收货方式(自提/外卖),是否使用优惠券,以及活动优惠。如果外卖需要选择收货地址,以及各种优惠之间的互斥关系,还有就是备注信息,不排除其他信息。这些数据都是在其他页面进行编辑后返回的,这样要保存太多的数据。数据的恢复又关联到UI的恢复。在这2000行代码里大动干戈的修改一个超低频率的bug,有丶吃力。说归说,当然该还要改的。

问题的总结:1.优化整体代码,降低内存占用。2.关键流程用Activity+fragment的方式,而不是Activity+Activity的方式,一个activity搞定,岂不美哉。3.拆类要趁早。

3.netty

netty的学习,总体来说,有点尬。洋洋洒洒的看了几篇分析博客。回头一看发现,我的sourceCode怎么跟他们的实例都对不上,后来才发现,大神大谈特谈的技术关键,都在server端工作。client端整体上的工作量,以及用到的关键点,比较少。sad。不过看了不亏。鉴于这部分只是都是看Blog。所以也不再啰嗦了。详细的讲解,可以看着个集锦《自顶向下分析netty》自顶向下深入分析Netty - 文集

一些技术点:java中的Future设计模式。netty中的Handle和Pipeline设计。

4.其他

下面是一些我也不知道为啥,反正这么干就行了的问题。

gradle在编译时在如下task时抛出error ---->:app:transformClassesWithAspectTransformForDebug Error:invalid entry CRC 

解决方法是:重装adt(好像是某个编译tool有点问题,损坏?)

JUnit version 3.8 or later expected  运行JUnit 进行单元测试,如上错误,在run选项中,edit configuration中删除所有junit测试的config。然后重新运行。

5.文章

异常代码定位在源码级别时的分析 当log的定位位置是sourceCode的时候,我是不会改的。都是系统的锅。没按我的想法运行。

实践App内存优化:如何有序地做内存分析与优化 - 掘金 大道理听过很多,可是我还没优化。这篇是我看过算是手把手教你怎么做了。


6.最后我想说的一点

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,117评论 25 707
  • 转载请注明出处(//www.greatytc.com/p/5f538820e370),您的打赏是小编继续...
    福later阅读 27,123评论 8 70
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,409评论 0 17
  • 如果我能预知 你我的离别 是天与地的距离 我不会把你 独自留在风里 想起当日的我 像一支箭射向远方 从此离开你的视...
    林嘉梓阅读 1,387评论 40 77
  • 前言 老规矩先来一篇前言,来说明一下当时的环境,便于看官们有良好的代入感。因为自己需要把windows下的mysq...
    风林火山91阅读 1,992评论 1 1