大扫除与代码重构

来源:互联网 发布:网络it需要什么学历 编辑:程序博客网 时间:2024/04/27 11:32

今天周六有几个朋友要来家里玩,为了让家里看起来不是那么凌乱,我从昨天晚上开始收拾屋子,今天一大早动员全家继续收拾,不知不觉就到了中午,这才总算看起来略显整洁。我当时一边奋力拖地,一边想,这收拾屋子跟维护代码还挺像的,要想保持屋里干净整洁就得勤收拾,而同样的整洁优雅的代码来源持续不断的优化,而房屋经常不收拾,最后就只能做大扫除,代码长期不整理,就得做代码大规模重构,否则羞于见人。

一、干净整齐的房屋在于勤收拾,优美简洁的代码在于持续优化

每次遇到家里狼藉,柜子里衣服成堆,东西找不着时,我就想,有没有一种好的收纳方法,能让房屋保持不乱、柜子整齐呢?于是,一通规划、一通畅想,这个专门用来做啥,那个专门用来做啥,发现要分门别类太难了,东西太多,到了最后把东西一股脑塞回去。过了几个星期或几个月,又全乱了。我一直很苦恼觉得是自己分门别类能力太差,是自己收纳方法不得当导致。今天,我突然醒悟,其实再得当的方法,一个礼拜不收拾、一个月不收拾,甚至半年不收拾,整个房屋肯定是乱哄哄!维护一个干净整洁的房屋,最好的办法莫过于勤收拾!

相形之下,维护代码就没有那么直观了,一般修改代码只有两种场景,"一、修复bug,二、增添新功能",没事别改代码,所以代码慢慢就变得不可理解了、变得凌乱了,只是房屋的乱你能直观感受,而代码乱是隐隐约约的,而且别人看不见。其实,最好的方式,莫过于持续优化,测试驱动开发(TDD)里面其实就讲,一边写代码一边重构,这是一种保持代码整洁优美的靠谱方式。

二、何时重构代码更好?到什么程度更好?

准确地说,我们应该随时优化、重构代码。就像收拾房屋,你可以随时收拾房屋以保持时刻干净整洁。但是,你可以试试抽一整天就呆在家收拾房屋,任务就是时刻保持房屋整洁,一天到晚都有收拾不完的地方。而代码优化更是如此,你可以不断抽象、不断让你的代码变得更好,只要不停止,永远都没完。所以,这样下去,你会很累,对于公司而言,成本很高。所以,我想这个可以用收拾房屋类比,大件规整好,大多数东西都归为,不影响取用,不影响其它活动,卫生不影响视觉,其它东西则依据个人习惯和时间充裕程度决定是否收拾。代码优化也一样,把握住基本原则,剩下的优化依据时间充裕度灵活处理。

三、方式、手段不限

收拾房间,你可以自己亲自动手、也可以请小时工,甚至或者自动化,比如各种机器人(这是可能是未来趋势),方式方法不限,只要能经常收拾保持整洁就行。代码优化也是,我们同样可以自动动手、或者自动化,或者其他方式,只要能优化。

四、该扔的扔

收拾房间,尤其时换季时,据人介绍第一步就是扔东西,东扔了才能腾出空间方更好的东西。我想代码重构也一样,重构过程该删除的代码就删,曾经规划的功能如果用处不大该舍弃的就舍弃。当然,很多人由于种种原因并不那么容易轻易扔掉那些曾经我们付出过情感,或者带给我们快乐的东西,可以打上标签,分阶段分次逐渐扔掉。毕竟,如果不扔它,那么带给我们的会是更多的麻烦。

五、大规模重构,出来混迟早都要还

如果我们长期将房屋凌乱置之不理,其结果是羞于见人,自己也心情越来越不舒畅,最后只能来一次大规模大扫除。同理,代码也一样,长期的忽视,换来的是忍无可忍的重构,最后必然欣开地毯全面清扫,或者从此废弃再不用。


0 0
原创粉丝点击