Bug很大,你忍一下
一个Bug到底能有多大?
几个历史数据转储逻辑Bug或发货逻辑Bug,就能让几十万轻松蒸发:
你们这亏钱的Bug都洒洒水啦,写Bug差点进去的见过没?
马上就有码农站出来表示不服,并表示自己参与开发的一款发薪软件曾出现Bug,会导致发放的薪资变成双倍,总共能多发2000多万。
当时查出Bug的时候发薪单已经生成,就差批量任务向银行发起请求了!
奇怪的胜负心就这么燃起来了。
一时间,什么水闸关不住、高铁追尾、甚至差点导致非洲国家内战的Bug都来了。
如果再放眼全球,你就会发现——Bug没有最大,只有更大。
2016年时,Excel就出过一个致使上万份遗传基因学论文出错的Bug。
很多长得像日期表达的长基因名的缩写(比如SEPT2、MARCH1),会在这一Bug的作用下被Excel自动转化成日期格式:
学术领域之外的Bug那就更牛逼了。
比如在1996年,欧洲运载火箭Ariane 5在发射37秒后当场爆炸。
一瞬间,70亿美元的开发费用全部木大,5亿美元的设备原地蒸发。
这一切都由一个整数溢出(Integer Overflow)的Bug引起。
而如果翻开维基百科上的这份专门统计历史上造成严重后果的Bug清单,沿着12个类别一个一个找下去,就会发现——
几乎每一条Bug的背后都存在着千万上亿的金钱损失。
有时,甚至会带来意外死亡。
1985年到1987年间,由加拿大AECL公司开发的Therac-25放射线疗法机器在软件互锁机制上出现了Bug,从而使辐射能量变成了正常剂量的100倍:
最终,至少有6名来自美国和加拿大地区的患者由于遭受过量辐射而意外死亡。
还有差点引发全球核战争的Bug:1983年苏联核警报误报事件。
△苏联军官Stanislav Yevgrafovich Petrov
在那一年的9月26日,苏联的雷达监测到了5枚自美军基地发射而来的导弹。
而上图的这位苏联军官权衡再三,最终将这一导弹攻击警告判断为误报,并没有按照规定向上级汇报并申请反击。
事实证明,这次DeBug成功避免了地球Online在1983年就发生重启。
“不是Bug是特性”
看完了上面那些惊天大活儿,瞬间觉得邮件/短信连环CALL这种Bug都温柔了许多。
像这种由于抽奖程序Bug导致的社死,好像也不是个事儿了:
而影响力又大,又没有造成严重损失,甚至让用户拍手叫好的Bug也不是没有。
比如一到游戏圈,Bug就会自动改名为特性。
△原神鱼竿Bug
某些知名游戏大厂甚至还会联名发布Bug马克杯,玩梗玩得飞起。
还有玩家真情实感地表示:Bug正是游戏复杂规则和交互的体现,我游YYDS!
△《矮人要塞》猫咪离奇死亡事件
甚至在游戏行业之外,还有用户在Bug被修复后愤怒投诉:
△图源知乎答主三和四保
最后,再回到“你的程序员生涯中写过的最大Bug”这一问题上来。
有回答选择直接结束比赛:
你们的程序员生涯中写过的最大Bug是什么?
——当初选择了做程序员
原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/151128.html