一、重构的定义:在不改变软件功能的前提下,改善代码的质量、使其程序的设计模式和架构更趋合理,提高软件的扩展性和维护性。
二、为什么要重构?很多人会说系统已经上线并运行好好的,我们为什么要重构呢,主要有以下几个原因:
1、随着业务需求一直增加,原本简短、清晰的代码会变得越来越糟糕;
2、随着业务的增加,现有的架构已经无法满足,或者开发效率在降低;
3、新成员的加入,代码风格不统一、质量存在问题;
4、系统存在性能问题,已经影响了系统的可用性;
5、系统的UI交互体验,已经不满足现有的用户的需求,影响用户使用系统;
6、发现有更好的实现方式。
三、重构的好处:重构不仅可以提升代码质量,还可以提升工作效率、减少bug的产生。任何架构都是随着业务的变化,不断演变出来的,而不是一开始都设计好的,所以学会重构是程序员的必备能力。
四、重构带来的问题。虽然我让大家一定要学会重构,并对系统积极重构,但重构也是会带来诸多问题的:
1、增加开发工作量、增加成本;
2、给系统引入新bug;
3、过渡设计,增加系统的复杂度;
4、过渡设计,降低性能。
五、保证重构质量。重构带来的问题,百分百要避免的就是引入新bug,而我们怎么才能保证代码的质量、把风险点降低呢,主要做好以下几个方面:
1、每一次重构都需要编写单元测试并通过单元测试;
2、迭代渐进式重构,不要一次性重构跨度太多,并保证每一步重构通过单元测试;
3、保证重构前后功能一致,可以通过所有测试用例;
4、测试重构前后的性能,虽然性能降一点点不会影响系统的运行,但如果降低太多,导致系统无法正常运行,就是bug了。
六、总结:重构任何代码都是有风险的,在重构启动之前,必须要梳理现有的系统,并制定必要的流程,保证每一个步骤都是准确无误的,并严格执行所有流程,这样才能把重构的风险降低。重构对代码编写能力、业务需求整理、团队协作、测试能力、管理能力各方面都有极高的要求,所以重构是非常容易失败的,但也是非常锻炼程序员的能力的。对于重构,虽然有诸多挑战,但我建议还是大胆地去重构。