程序员为什么要不能一次性写好,需要一直改bug ?

5个月前 (11-29) 0 点赞 0 收藏 0 评论 7 已阅读

你是一个优秀的程序员,现在被要求写一段程序:

“输入两个数A、B,输出它们的和。”

题目甚是简单,你大笔一挥,写下:

输入“A”、“B”;计算“C=A+B”;输出“C”。

你自己测试了一下:输入“1”、“2”;输出“3”。程序很棒,于是你交给用户了。

用户:输入“127”、“1”;输出“-128”。

你思考了一下,原来是8位int只能支持-128~127的整数。于是你大笔一挥,改成了64位的int,这下能支持-2^63~2^63-1了。顺便,你还编写了一段数据验证的判断,如果超出int的范围还会提示“数值过大”。非常贴心。

用户:输入“1.5”、“2.5”;输出“3”。

你心想,当时没人告诉我会有小数计算啊,过几天岂不是还会有无理数运算。你和用户一顿沟通,他向你发誓最多只会有小数计算,绝对不会有无理数。于是你把数据类型改成了double,这下可以支持小数了。

用户:输入“0.1”、“0.2”;输出“0.300000000000004”。

你回顾了一下大学学到的知识,想起double类型并不是那么精确。所幸用户不是开银行的,对数据精确性要求不那么高,甚至偏差个±0.01都能接受。于是你在数据输出时四舍五入了一下,保留两位小数,这下0.1+0.2=0.3了。

用户:输入“一”、“二”;输出“0”。

你和用户大吵了一架,终于说服他不在输入框里填汉字。以防万一,你给数据输入加了一段验证,只接受两个带符号小数。而且对于数字过大、过小都会提示超出范围。这下终于没问题了,你心想。

过了几天,你在知乎上看到一个问题“为啥程序员不能一次性把程序写好?”

程序员为什么要不能一次性写好,需要一直改bug ?

本文收录在
0评论

登录

忘记密码 ?

切换登录

注册