★
Bug,总是令人讨厌的东西。那Bug是如何产生的呢?作为高级软件架构师和软件测试工程师的易哥将在这篇文章中解答这个问题。
”
说起Bug,大家都认为它是被“写”出来的,即主要在开发阶段产生。
但其实Bug的产生最有可能是在需求阶段(意外吧!这是有统计数据证明的),且在需求阶段产生的Bug影响最大。当然,在设计、开发、使用阶段也会出现Bug。
接下来我们详细了解下Bug的相关知识。
1. 什么是Bug
Bug,指软件中的缺陷,它可能会引发软件失效。
关于软件中的缺陷被称为Bug,即虫子,这是有一段故事的。在早期的计算机中,常采用大量的继电器,用继电器的开合来表示二进制。马克二型计算机就是这样的。1945年9月9日,下午三点,马克二型计算机无法正常工作了,技术人员试了很多办法,最后定位到第70号继电器出错。负责人哈珀观察这个出错的继电器,发现一只飞蛾躺在中间,已经被继电器打死。她小心地用摄子将蛾子夹出来,用透明胶布帖到“事件记录本”中,并注明“第一个发现虫子的实例。”自此之后,引发软件失效的缺陷,便被称为Bug。
2. 能做出完全没有Bug的软件么?
很抱歉,答案是不能。
任何软件都有缺陷,这是软件测试领域的一个真理。
在软件质量标准中,软件的可靠度用R(t)表示,它表示在指定的运行条件下,软件在规定的时间内不发生故障的概率。
一定有R(0)=1,即软件在初始运行时刻一定是无故障的,否则说明软件还没有开发完成,尚不能运行。一定有R(+∞)=0即任何软件都是有缺陷的,在无限长时间运行后一定会发生故障。
3. 在故障原因上,软件有何特点
与我们常见的桥梁、楼宇、手机、文具等各类实体产品不同,软件有一个非常重要的特点:它不会因为复制、运行而发生衰退。
毕竟软件不会生锈、老化、分解等。这算是软件的一大优点。
因此理论上,我们可以通过不断的投入测试成本来降低软件发生故障的概率。但即便如此,软件的故障概率会趋向于0,而永远不会等于0。
况且,在现实中“不计成本”这种事情是不会发生的。
现实中的软件往往存在大量缺陷,其一大原因是因为软件的复杂性。具体可能产生bug的因素会在下节讲。
软件测试十分必要。但是要记住一点,软件测试不是为了清除软件中的bug,而是减少软件中的bug。
4. Bug是如何产生的?
这就回到了我们问题的重点,Bug如何产生。
接下来我们按照软件的生命周期顺序一一介绍。
A: 需求错误--未知需求
问:这个软件为什么不能上传Excel导入数据?
愣:开发前你有提到过说要用Excel导入数据么?
B:需求错误--未理解需求
问:这个软件为什么按钮文字上没有拼音?小朋友不认识字啊?
愣:啥?小朋友?啥?拼音?
C:设计错误--模型选择错误
问:这两个操作能不能一起执行啊?
愣:坏了,选的是责任链模式,不支持并行啊!
D:设计错误--模式选择错误
问:再接一个输入源好不好?
愣:没采用适配器模式,不好改啊!咋办?
F:设计错误--框架选择错误
问:好,那我们去手机端看一下页面。
愣:完了,选的框架不支持动态适配。还看啥啊,二手手机交易平台界面一定乱了!
G:设计错误--并发不达标
问:为什么人少的时候可以,人一多就会停止服务?
愣:坏了,当时没考虑这个问题。
H:设计错误--兼容性不达标
问:我们升级了一下别的应用,它就不工作了。
愣:坏了,写死绑定那个应用了,那个应用不能升级啊。
I:设计错误--容量不达标
问:数据一多,就存不进去了。
愣:坏了,设计的容量出问题了。
J:开发错误--外部依赖缺陷
问:这个地方报错了。
愣:妈蛋!引用的开源包有问题!
K: 开发错误--死循环
问:点一下就死机了。
愣:我看看,你这么输入的啊……那,坏了,触发死循环了。
L: 开发错误--越界
问:数个空格进去,就报错了。
愣:坏了,空格被忽略了,但是计数器没调整,肯定越界了。
M:开发错误--异常未捕获
问:没网络的时候,点一下就死机。
愣:坏了,有异常抛到了最上层。
N:开发错误--IO未关闭
问:重启完机器就正常了,过几天就没响应了。
愣:搞半天,每次操作都忘关IO了,导致socket被耗尽。
O:开发错误--空指针异常
问:突然就死掉了。
愣:原来是,文件没找到,报了NullPoniterException。
P:开发错误--变量混乱
问:输出的结果,驴唇不对马嘴。
愣:我去,变量wife和wifi用混了。
Q:开发错误--手误
问:为什么显示“下楼好”?。
愣: 奥,输错了,应该是“下午好”。
R: 开发错误--日志未关闭
问:硬盘被打满了!
愣:是不是正式版忘了关调试日志?
S: 开发错误--内存未初始化
问:第一遍运行正常,第二遍就有乱码。
愣:难不成,变量没初始化?
T: 开发错误--类型转换异常
问:全数字的身份证号是没问题的,一输入后面带字母X的就报错。
愣:坏了,把身份证号当数字处理了。
U: 开发错误--颜色设置错误
问:为啥他登陆后名字是绿色的?
愣:奥,错了,应该是背景是绿色的,弄混了!
V: 开发错误--忘记屏蔽
问:为啥她能看到我的密码?
愣:我去,大问题!忘了脱密了!
W: 使用错误--忘记插线
问:为啥鼠标无法操作?
愣:我去,你鼠标线都没插。
X: 使用错误--输入错误
问:为什么总是说信息输入错误?
愣:你为什么在“姓名”栏位写个“男”
Y: 使用错误--理解功能错误
问:为啥你的软件不能显示附近的人?
愣:这是外卖软件……约人的活真干不了。
因此要想保证软件的正确,必须保证需求、规划、开发、使用各个环节都正确。这,太难了。
可见,软件开发者不容易。
写一个成功软件的道路没几条,而写一个失败软件的道路数不清!
要不是英文字母不够了,还能列举下去!
Z: 使用错误--操作失误
问:为什么不能点赞?
愣:你点了么?再点一下试试!
往期精彩文章:
高效日志系统搭建秘技!架构师必读程序员最有成就感的那一刻是什么时候?远程过程调用RPC的实现原理:动态代理
欢迎关注我们,不错过软件架构和编程方面的干货知识。