黑龙江省网站备案,广州网站开发广州亦客网络解答,企业微网站案例,淘词神器转载自 成为更优秀的程序员#xff1a;退后一步看问题
一天#xff0c;在工作中… Bug #3890 来自客户#xff1a; 有个程序出现了错误#xff0c;程序提示说“SpeedCalculator::compute()里出现了除零情况”。 请尽快修复#xff01; 你打开SpeedCalculator.php#…转载自 成为更优秀的程序员退后一步看问题
一天在工作中… Bug #3890 来自客户 有个程序出现了错误程序提示说“SpeedCalculator::compute()里出现了除零情况”。 请尽快修复 你打开SpeedCalculator.php发现 修复bug
简单是谁写的这段代码他怎么不用一点脑子 你就这样修改完了这个bug只用了你2分钟。
后来同样的bug又出现在了RatioCalculator和MoneyCalculator中当把它们也修正后团队中的所有人都认为再也不会有这样的问题出现了这是最后一次代码现在又是坚固无比了
一个月后另外一个bug出现了。这次程序没有崩溃但客户在报表中发现了错误的计算结果是因为那句return 0;的代码修改。
退后一步看问题
如果我们不是匆匆忙忙的修改而是退后一步以更宽广的视野看待些问题。 为什么这种事情会发生 因为$this-time被赋值成 0. 简单让我们阻止这种事情发生。 这样修改的效果不是更好吗你保证了数据的正确性。但这样客户并不是很高兴因为当他输入0时程序会跳到一个错误页面。
那么你应该在控制层捕捉这个错误让用一个漂亮的错误页面显示它们。
当做完了这些你认识到在RatioCalculator和MoneyCalculator中你也应该这样做于是你拷贝/张贴修改了它们两个。
稍等一下客户更喜欢让错误信息显示成橘黄色的而不是红色的。于是你再次拷贝/粘贴再次修改一遍。
再退后一步
如果我们不是修复这个不过而是发现了一个普遍的要求
为什么客户会输入 0 因为他犯了个错误。
这对我们的要求是什么 我们只需要这次防止用户输入 0 来避免“speedCalculationForm 0”吗 我们只需要让“speedCalculationForm”里的数据合法就行了吗 还是我们要对所有的用户输入继续校验
为什么不开发一个校验工具包呢
且慢不要自己去开发一个请退后一步想想深呼吸去使用现有的第三方校验框架。 关于需求
我们程序员热爱计算机技术。当你的客户或老板大声的脱口说出他们想要的东西时我们无法阻止我们只能想象如何去实现它们。
但是我们需要用更全面的眼光看问题。如果我们想对自己的工作更负责我们应该去理解为什么他们会提出这样的需求而不是着急着去寻找解决方案。当然这可能会占用你更多的精力。
是客户真的需要“一个会躲避鼠标点击的闪光的按钮”吗还是他们需要的是另外一个功能——他们不了解的功能需要你去帮他们定义的功能这种事情同样会发生在你自己身上你真的需要用程序打开一个文件往里面写入一些信息吗还是你真正需要的是一个日志系统
退后一步看问题看更大的蓝图、更完整的信息。虽然你是一个很优秀的编程高手但编程的目的是为了解决问题。