注册用户享全站资源 并成为粉丝 不定时福利发放
 

成为更优秀的程序员:退后一步看问题

8
发表时间:2018-11-19 14:02

请把下面的[客户]、[老板]或其它任何东西换成你想要的名称。

一天,在工作中…

Bug #3890 来自客户:

有个程序出现了错误,程序提示说“SpeedCalculator::compute()里出现了除零情况”。

请尽快修复!

你打开SpeedCalculator.php,发现:

publicfunctioncompute(){return$this->distance/$this->time;}

修复bug

简单!是谁写的这段代码,他怎么不用一点脑子!

publicfunctioncompute(){if($this->time==0){return0;}return$this->distance/$this->time;}

你就这样修改完了,这个bug只用了你2分钟。

后来,同样的bug又出现在了RatioCalculatorMoneyCalculator中,当把它们也修正后,团队中的所有人都认为,再也不会有这样的问题出现了,这是最后一次!代码现在又是坚固无比了!

一个月后,另外一个bug出现了。这次程序没有崩溃,但客户在报表中发现了错误的计算结果,是因为那句return 0;的代码修改。

退后一步看问题

如果,我们不是匆匆忙忙的修改,而是退后一步,以更宽广的视野看待些问题。

为什么这种事情会发生?

因为$this->time被赋值成 0.

简单!让我们阻止这种事情发生。

publicfunctionsetTime($time){if($time==0){thrownewInvalidArgumentException("Invalid value");}$this->time=$time;}

这样,修改的效果不是更好吗?你保证了数据的正确性。但这样客户并不是很高兴,因为当他输入0时,程序会跳到一个错误页面。

那么,你应该在控制层捕捉这个错误,让用一个漂亮的错误页面显示它们。

当做完了这些,你认识到,在RatioCalculatorMoneyCalculator中,你也应该这样做,于是你拷贝/张贴,修改了它们两个。

稍等一下,客户更喜欢让错误信息显示成橘黄色的,而不是红色的。于是,你再次拷贝/粘贴,再次修改一遍。

再退后一步

如果,我们不是修复这个不过,而是发现了一个普遍的要求?

为什么客户会输入 0 ?因为他犯了个错误。

这对我们的要求是什么?

  • 我们只需要这次防止用户输入 0 来避免“speedCalculationForm = 0”吗?

  • 我们只需要让“speedCalculationForm”里的数据合法就行了吗?

  • 还是,我们要对所有的用户输入继续校验?

为什么不开发一个校验工具包呢?

且慢!不要自己去开发一个!请退后一步想想,深呼吸,去使用现有的第三方校验框架。

关于需求

我们,程序员,热爱计算机技术。当你的客户或老板,大声的脱口说出他们想要的东西时,我们无法阻止,我们只能想象如何去实现它们。

但是,我们需要用更全面的眼光看问题。如果我们想对自己的工作更负责,我们应该去理解为什么他们会提出这样的需求,而不是着急着去寻找解决方案。当然,这可能会占用你更多的精力。

是客户真的需要“一个会躲避鼠标点击的闪光的按钮”吗?还是他们需要的是另外一个功能——他们不了解的功能,需要你去帮他们定义的功能?这种事情同样会发生在你自己身上!你真的需要用程序打开一个文件,往里面写入一些信息吗?还是,你真正需要的是一个日志系统?

退后一步看问题,看更大的蓝图、更完整的信息。虽然你是一个很优秀的编程高手,但编程的目的是为了解决问题。


会员登录

会员登录

登录免费下载全站资源

获取验证码
登录
登录
开发简历

开发简历

简历模板网站自取

入坑需谨慎

入坑需谨慎

高薪完全靠自己

微信赞助-Java帮帮社区

微信赞助-Java帮帮社区

非盈利性学习社区

支付宝赞助-Java帮帮社区

支付宝赞助-Java帮帮社区

将分享做到极致

大公司资讯
文章附图

近日,在美国推出满一年的Facebook视频服务Watch,宣布正式向全球推广,这预示着视频领域中,YouTube...

文章附图

据彭博社北京时间9月19日报道,科技行业最引人注目的法律大战可能正在进入尾声。据高通CEO史蒂夫·莫伦科夫(Ste...

Java帮帮公众号生态

Java帮帮公众号生态

总有一款适合你

Java帮帮-微信公众号

Java帮帮-微信公众号

将分享做到极致

Python帮帮-公众号

Python帮帮-公众号

人工智能,爬虫,学习教程

大数据驿站-微信公众号

大数据驿站-微信公众号

一起在数据中成长

九点编程-公众号

九点编程-公众号

深夜九点学编程

程序员服务区-公众号

程序员服务区-公众号

吃喝玩乐,听学吐画

Java帮帮学习群生态

Java帮帮学习群生态

总有一款能帮到你

Java学习群

Java学习群

与大牛一起交流

大数据学习群

大数据学习群

在数据中成长

九点编程学习群

九点编程学习群

深夜九点学编程

python学习群

python学习群

人工智能,爬虫

测试学习群

测试学习群

感受测试的魅力

Java帮帮生态承诺

Java帮帮生态承诺

一直坚守,不负重望

初心
勤俭
诚信
正义
分享
合作品牌 非盈利生态-优质内容分享传播者
关于我们
友链申请
友链交换:加帮主QQ2524138991 留言即可 24小时内答复  
全站内容非商业用途,内容来源于网友,并遵循 CC BY-NC 4.0 许可,如有异议请联系客服。
会员登录
获取验证码
登录
登录
我的资料
留言
回到顶部