失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > mysql小鸭子_可读代码编写炸鸡十一 - 小黄鸭从你的心里游到脑子里

mysql小鸭子_可读代码编写炸鸡十一 - 小黄鸭从你的心里游到脑子里

时间:2022-02-01 07:28:18

相关推荐

mysql小鸭子_可读代码编写炸鸡十一 - 小黄鸭从你的心里游到脑子里

可读代码编写炸鸡十一 - 小黄鸭从你的心里游到脑子里

多选参数推荐搜索

数据结构与算法

可读代码编写

Java

Redis

MySQL

大家好,我是多选参数的大炮。

可读代码编写的炸鸡很快要写到头了,从一开始的尝试到现在的倒计时,还是有一些成就感的。当然,这不是炸鸡篇幅缩短的托词。而是越到后头,其实内容越少,越需要代码的实践。在上一篇炸鸡的结尾,我也提到了这一点,所以各位勿怪。

我们已经了解了,抽取不相干子问题,让代码段尽量一次只做一件事对于代码可读性的优化,但是这些都是针对已经出现不好代码的情况。

而很多情况下,你要面对不少前人留下来的你不愿面对的糟糕代码,并且修改他,从此背上这口大锅。不过如果他们能在写之前就能想清楚该怎么写能尽量使代码通顺可读干净,你也少背锅,岂不美哉。

更何况,在编码前就要提醒自己尽量写出可读性高的代码,这也是对于自身的要求,与项目垃圾与否无关,不是吗。(当然,这句话是从我同事那里偷来的,他叫 pickline。)

再回顾一下可读代码编写的第三层:

后台回复 「第三层」获取源文件

所以接下来两篇炸鸡,都是站在编码前就考虑如何减少不好代码的角度而提供的建议。

小黄鸭

各位或许都听说过,小黄鸭调试法吧,所谓的小黄鸭调试法就是:当程序员面对 bug 却不可自查,陷入困顿时。在电脑旁放一只小黄鸭,一边抚摸它一边讲述自己的代码思路与流程,希望借此找到代码的漏洞。

所以这只小黄鸭完全可以用在编码,也可以称作小黄鸭编码法。小黄鸭编码法就是面对一段需要实现的功能,先自己想一遍,说一遍功能的大致流程与细节,然后再对应地编码。

编码前的大脑

《编写可读代码艺术》第十二章中也提到,其实写程序,就是人利用计算机语言来向计算机解释一件事情,就好像我们跟朋友讲述一个故事。所以自己说一遍自己要写的东西,是有帮助的。

小黄鸭编码法对可读性的提高有所帮助,尤其是一些较为复杂的逻辑判断,这个在业务中也是常见的校验流程。

如果发现自己代码整体有点复杂冗长,就更应该先小黄鸭一下,理清楚思路,而不是盲目上手。提高可读性的方法是很多,但是从一开始就规范起来,可以少走弯路。

假设我们一个依据配置提供下一题这样的业务需求。在编码前,我们的大脑可能不太清醒,认为的步骤是这样的:返回一个 next question。

question 有跳转类型,any 和 right 才有 next question 的数据,如果是 right, 需要答对才能继续。

同时回答题目没有结束。(not isEnd)

没结束需要看 nextQuestionId, -1 的是随机,不然就是固定。

好了 ,如果依据这样的想法,我们写出了之前炸鸡中出现的例子来了。functionQuestionSystem:giveNextQuestion(questionId,isAnswerCorrect)

localquestion={

isEnd=false,

maxAnswerTime=11,

nextQuestionId=0,

}

localquestionConfig=Config.getConfById(questionId)

ifquestionConfig.nextType==NEXT_TYPE.ANY

or(isAnswerCorrect

andquestionConfig.nextType==NEXT_TYPE.RIGHT)then

ifnotself:isEnd()then

self._count=self._count+1

question.isEnd=false

--随机一个

ifquestionConfig.nextQuestionId==-1then

question.nextQuestionId=math.random(1,questionConfig.maxNum)

else

question.nextQuestionId=questionConfig.nextQuestionId

end

question.maxAnswerTime=Config.getConfById(question.nextQuestionId).maxAnswerTime

returnquestion

else

question.isEnd=true

returnquestion

end

end

end

写出的代码可读性较差,也反映了你的脑子里,还是稍显混乱的。

小黄鸭的游动

那么这时候,我们完全可以利用小黄鸭编码法,重新在讲述一遍业务需求和代码思路,将刚才稍显混乱的想法重新梳理。小黄鸭在你的心里出生,而它随着你的思绪游动到脑海。我觉得刚才的思路需要重新梳理。

回答结束了,就直接结束了,不搞太多东西。

如果回答没结束需要看跳转类型,不符合就没数据返回。

确定有下一题,下一题需要确定随机还是固定生成。

接着把想法倾泻到代码中:functionQuestionSystem:giveNextQuestion(questionId,isAnswerCorrect)

localquestion={

isEnd=false,

maxAnswerTime=11,

nextQuestionId=0,

}

ifself:isEnd()then

question.isEnd=true

returnquestion

end

localquestionConfig=Config.getConfById(questionId)

localnextAnyway=questionConfig.nextType==NEXT_TYPE.ANY

localnextNeedRight=(isAnswerCorrectandquestionConfig.nextType==NEXT_TYPE.RIGHT)

ifnotnextAnyway

andnotnextNeedRightthen

returnquestion

end

self._count=self._count+1

question.isEnd=false

ifquestionConfig.nextQuestionId==-1then

question.nextQuestionId=math.random(1,questionConfig.maxNum)

else

question.nextQuestionId=questionConfig.nextQuestionId

end

question.maxAnswerTime=Config.getConfById(question.nextQuestionId).maxAnswerTime

returnquestion

end

嵌套减少了,思路清晰了,可读性也提高了。

小结

全篇炸鸡其实都在讲一件事情:小黄鸭编码。其实小黄鸭编码就是给自己一个同自己的想法对话的机会。

其实从事编码相关的工作也有一年了,个人感觉编码过程中最冒失的事情便是 —— 直接下手去写。倒不是反对实践,是反对盲目下手。因为这个时候那只小黄鸭还未振翅游来,你的思路是没有打开的,不仅可读性可能受到破坏,而且很可能达不到所需。

如果在编码之前,先同自己对话,找到一只小黄鸭,慢慢地梳理思路,势必会比莽撞敲键盘来得好。而且这也花不去多少时间,着什么急呢。

不甘于「本该如此」,「多选参数」值得关注

如果觉得《mysql小鸭子_可读代码编写炸鸡十一 - 小黄鸭从你的心里游到脑子里》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。