柳诚来到了汪永丰的电脑前,指着他写的一段代码说道:🈑♒🇲“你看这里,你就有九处嵌套,过一段时间,你自己看,都得懵。”
他说着有打开了另外一段日志宝的代码说道:“你看我这段,我的这段嵌套分🚵支也很多,但是这都不🝛🝠是一次写出来的,而是每次增加新🐄☸🄊功能时就开个新的分支。”
“对于每一个分支的增加,我都不觉得需要重构整段代码,因为我当时只🎣💸🖥想用最快的时间,把自己要做的事🕎🈡⛞🕎🈡⛞情做完,于是代码质量变得越来越低。”
“昨天晚上,我就把这段代码进行了重构,将三百二十行,变成了一百行,这样就不担心启明星的工程师们看晕头了⛚,也节省了大量的资源。”
汪永🎐丰看🛞着两段代码,点了点头说道:“区别真的很大,但是功能相同。那应该怎么重构🍷🌪代码呢?”
柳诚接过了柳依诺递过来的水🟙🝥🍓杯,说道:“一般情况下,三个分支就可以重构为一个判断(switch),如果一个判断的分支大于10个,就要考虑写成表🐸🄨(fig)去驱动,专门写一个函数根据配置写一个路线图(mapping)。”
“如果是映射逻辑复杂,使用频率较高🏵,💰🕟就专门写一个数据库🖂规则引擎(ruleengine)来调用。”
汪永丰还是有点懵,柳诚🜾🇲🜟又亲自演示了一遍,有些犹豫的说道:“就是类似这🚵种,重构代码是个费力🝛🝠不讨好的活儿,但是也是一个必做的工作。”
“好厉害!”汪永丰眨着眼睛,😓目瞪口呆的说道。
柳诚示意这没什么,笑着说道:“大部分都是这样,我曾经接手过一个三十几层的if😧🃭else套if🄝else模块,把我差点干崩溃。”
“我对这个模块🝞,做评审复盘的时候,🏵发现第一个程序员,只写了一层,后来每增加一个需求,逻辑分支扩张到了三十多层,就没人愿意重构了。”
“重构错了,还得背锅。”
“我那时候🈞就劝自己,编程嘛,最重要的就是看得开,我加了一层,测试,提交,下班。”
汪永丰十分好奇的问道:“后来呢?”
柳诚满是回忆的说道:“后来这个模块,在启动的时候🞻🙔,会被执行19.6亿次,开启这个模块的时间长达六分钟,而且所有人都不知道问题出在哪里。”
“19.6亿次?”汪永丰拍了拍额头。
柳诚站起身来,笑着说道:“是一个游戏在线服务的子模块,你👲🌮知道,19.6亿次的无用运算,一遍又一遍的在用户的CPU上上演,那场面,啧啧。”
“后来呢?”汪永丰瞪着眼睛,问道。
柳诚笑眯眯的说🝞道:“后来呀,我偷偷的改了呀,还能咋样,要是被公司发现,我岂不是要被炒鱿鱼?”
人生的路🛞上,有很多的经验,🟙🝥🍓都很一个坎坷一个坎坷,跨过去之后,🌢🀵🁅才恍然大悟,当初就不该犯这样的错误。
自那以后🛞,柳诚过手的大大小小的模块,都会用当初师父交待的方法,进行一遍遍🃱的重构🍷🌪,背锅不可怕,发生不可挽回的错误才是最可怕的。
“柳工,你这么🝞厉害,还有功夫谈🖾😒恋爱啊。”汪永丰十分苦恼的👲🌮说道:“我学都学不过来,每天所有的时间都用完了,还是不够用。”
柳诚站起身来,笑⚣📑🚇眯眯的说道:“谁让我天赋异禀。”
“对了,你现在不要过分追求什么代码精简、简洁,而是踏踏实实的做完项目,一个程序员不要操着C🄝TO的🛳心。”