概述
- 重构的目标可以量化,或者说可以测试吗?
- 重构完成的标准是什么?得到业务部门或者领导的认可了吗?
3.3 渐进式重构
现在软件研发最流行的就是快速迭代、持续交付、尽早反馈。这同样可以用在架构的重构上,重构过程的难度不亚
于构建一个新产品,所以在设计重构的时候,要引入持续交付的流程,每一个重构步骤或者模块都要快速部署并得到反馈,以便评估重构的效果,及时作出策略调整。经过谨慎测试之后,将数据和业务迁移过去。检查清单:
- 能否把重构过程分成小的迭代,每一次改进都能尽快得到反馈?
- 重构过程中的效果能够定期展示给业务部门或者领导吗?
3.4 确定当前的架构状态
在启动重构之前,团队要对当前的架构状态有清晰的了解,也就是设定好基准,以便评估重构的效果。据我的观察,负责重构的架构师或者开发者,往往还没有搞清楚现有的架构设计,就开始重构了,结果经常出现这样的情况:重构到某个阶段,发现行不通,然后一拍脑袋说,哦,原来这块的架构是这个样的,是为了达到某某业务需求啊,这块不能动,得想别的办法。类似的例子在研发团队中时有发生,也提醒我们要慎重小心。检查清单:
- 你了解当前的架构设计吗?它的设计初衷和之前的选型方案知道吗?
- 你能给架构设定一个基准状态吗?
3.5 不要忽略数据
数据的重要性不言而喻,业务都是以数据流为载体的,所以架构重构的本质就是对于数据流的重构。数据对重构的重要性主要体现在两个方面:在重构设计时,需要考虑业务数据的需求,重构之后的系统对于数据的存储、处理、分析等功能是否有影响;在重构过程中,考虑依靠数据甚至是实际的数据来验证重构的效果,提供评估的支持。检查清单:
- 业务数据的需求在重构设计中有体现吗?
- 重构过程中能否通过实际数据来验证效果?
3.6 管理好技术债务
技术债务在平常的软件研发过程中也是比较突出的问题,架构重构往往是为了偿还技术债务,所以请不要在偿还技术债务的过程中制造技术债务了。技术债务就像信用卡一样,会有很高的利息率,就如同给团队留下了大量的帐务开销。组织应该培养一种保证设计质量的文化。应当鼓励重构、同时也应当鼓励持续设计以及其它有关代码质量的实践。在开发时间中应当专门抽出一部分以解决技术债务。检查清单:
- 团队对技术债务有跟踪和备忘录机制吗?还是开发人员可以随意的产生债务?
- 针对技术债务有定期的培训、回顾机制吗?
3.7 远离那些虚荣的东西(例如使用“热门”的技术栈)
架构的重构过程应该是以目标为导向,换句话说“注重实效”。对于技术人来说,一个经常被轻视的问题在于,喜欢追逐新鲜的热门技术,这其实是个好事情,说明技术人勇于创新,不断接受新技术。但是对于架构的重构这样的关键性任务来说,是不是新技术并不重要,重要的是能不能实现重构的目标。对于新技术来说,虽然热度大,但大家踩过的坑还不多,积累的失败教训和成功经验还不够,在这种情况下,建议大家不要头脑一热就上马新技术,应该客观冷静地评估新技术和成熟技术对架构重构的影响和效果,以数据和经验来说话,而不要追赶时髦。检查清单:
- 重构的技术选型是否有详实的数据和专家评估?
- 选用的技术是否有良好的人才积累和足够的经验支持?你是不是实验小白鼠?
- 在技术选型时,是否至少有两个方案待评估?有没有成熟的技术方案?
3.8 做好准备面对压力
软件开发过程中,压力无处不在。对于架构重构来说,压力来源于多个方面:管理层、团队成员、同级部门等等。说白了,架构重构对个人来说往往是一件出力不讨好的事情。和做一个新产品能够取得很高的赞赏相比,重构的成绩往往并不受领导重视,而且出了问题还要承担很大的责任。从软件开发角度看,做新产品是从 0 到 1,而架构重构是从 -1 到 1,复杂性和难度通常更大。因此,重构的负责人要提前做好心理准备,舒缓压力的一个技巧是,设置好里程碑,将重构的成果量化,并且和业务的变化关联起来,定期向利益相关各方同步状态,得到大家的理解和支持。检查清单:
- 架构的重构是否得到了管理层(特别是最高管理层)的支持?他们是否对重构的时间、任务量有直接的认识?
- 你的重构计划中是否包含了一些可以量化的成果?是否定期向管理层展示这些成果?
3.9 了解业务
架构重构的最终目的是改进业务,所以对于业务的了解将有助于架构师和技术人确定重构目标的优先级和关键路径。比如,我们需要知道哪些关键业务的架构是不能碰的,哪些业务之间是互相关联的,哪些业务的架构是需要优先重构的……等等。除了了解业务本身,我们还需要了解“人”,表面上管理层是重构目标的裁决者,但实际上业务部门的人才是。技术人需要了解他们的业务需求,并将其转化为重构目标。通过这种方式,架构重构的意义才能得到具体的体现。检查清单:
- 是否与业务部门就架构重构所能实现的业务目标进行过充分的讨论和确认?
- 是否对关键业务和优先重构的业务进行了确认?
3.10 做好面对非技术因素的准备
不管你是否愿意相信,技术在架构重构(以及其他很关键的公司决策中)的影响因素中并不是最高的,我们还会涉及到商业利益、管理层偏好、大客户影响、团队问题等等,对于架构师和技术人来说,这些因素往往不是他们所能掌控的。我们能做的就是,与利益相关者设定重构目标,然后,根据不同的影响因素,调整目标。请记住,不要死扛这个目标,当有人提出不同的意见时,要坦诚地和他们交流,并告知他们如何采纳意见,那么重构目标会有变化,然后让其他利益相关者也知道这些变化。非技术因素的影响是客观存在的,而且从商业层面来说也是合理的,所以对于技术人来说要学会适应。检查清单:
- 当非技术因素影响架构的重构时,你是否对目标做了调整并告知了利益相关各方?
- 你是否准备以开放而不是抵制的心态来对待非技术因素的影响?
3.11 对于代码质量有所掌握
架构的重构对代码质量要求很高,一方面是重构过程对 Bug 的容忍性比新产品的研发更低,另一方面也决定了下一次重构的难易程度。代码审查是一个非常好的办法。代码审查是软件开发过程中的必要步骤,既可以帮助被审查者提到代码质量,又可以让审查者加深对产品的理解。不论团队多忙,一定要保证代码提交之前,是经过其他成员审核过的,短期来看会占用团队的时间,长期来看是事半功倍的好事。检查清单:
- 团队成员是否对代码质量有足够的重视?是否有奖惩措施?
- 团队内部是否有代码质量的标准文档和审查流程?
四、结尾
关于架构的重构,一切来源于实践中的经验是最有价值的,为技术人所用才是有意义。
最后
给大家分享一份移动架构大纲,包含了移动架构师需要掌握的所有的技术体系,大家可以对比一下自己不足或者欠缺的地方有方向的去学习提升;
给大家分享一份移动架构大纲,包含了移动架构师需要掌握的所有的技术体系,大家可以对比一下自己不足或者欠缺的地方有方向的去学习提升;
最后
以上就是动人小馒头为你收集整理的开发过程中项目是否需要重构?又需要注意什么?,Android架构组件Room功能详解的全部内容,希望文章能够帮你解决开发过程中项目是否需要重构?又需要注意什么?,Android架构组件Room功能详解所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复