这 BUG,绝了
阅读原文时间:2022年05月11日阅读:1

上周只上了三天班,但我也丝毫不敢懈怠,BUG 更是一个也没少写。

看着满屏幕的 ERROR,我陷入沉思。为什么我写的代如此烂,无法像大牛们写的那般优雅?

越想越自卑,越想越抑郁。我觉得这样不行,一定得振作起来。

正如一位哲人曾经说过:

世间万事万物,都是有两面性的:有它光明的一面,也就有他阴暗的一面;有它积极的一面就有他消极的一面;有他好的一面也有它坏的一面。

我的代码虽然不够优雅,但写的 BUG 还能比别人差吗?

然后我在网上搜了一下,没错,BUG 也比别人差。

软件开发历史上有哪些著名的 BUG 呢?今天我们就来好好聊一聊,涨涨奇怪的知识点。

上图中有一只飞蛾被贴在了一张纸上,这可不是某个人的特殊爱好,而是计算机的第一个 bug。

它导致了哈佛 Mark II 计算机中的继电器短路。Grace Murray Hopper 找到了它,并把它放在了日志中。

如果没有这个 bug,我们可能对计算机中的错误就有不同的说法了。

这可能是最著名的计算机错误了。

一位国外做邮件服务的管理员,有用户向他抱怨说:他们不能发送超过 500 英里距离的电子邮件。

这不是扯淡吗?这可是互联网业务,怎么还跟实际距离有关了。

管理员一听也是一脸懵逼,根本不相信。根据程序员法则即可推理:原来还好好的呢。

有一位用户还特意做了一张邮件发送失败的地图。地图上显式,邮件的送达区域半径比 500 英里就多那么一点点:半径内的收件人,全收到了,之外的,全失败了。

看来是真的有这个问题,还是得排查啊。到底是怎么回事呢?

原来是一次软件升级导致远程服务器超时时间被设为 0。在一个具有典型负载的特定机器上,零超时意味着如果连接时间稍微超过 3 毫秒,服务器就会终止连接。

而以光速传播的电信号,在 3 毫秒的时间内所能到达的距离大约是:

0.003 * c (光速) = 558.84719 miles

一家医院用来监控病人健康的数据库,每到周三,会自己崩溃。

我就不一样了,我是周一到周四都会崩溃。只有周五状态正常,因为马上就要修周末了。

说回这个系统,该系统记录日志是用 C 风格的代码编写的,把日志字符串记录到了一个固定长度的缓冲区中,其中日志时间一栏,格式例如「Monday, July 17, 1997, 10:38:47.123」。

看到这是不是有点灵感了,肯定是跟时间有关系,让我们把信息再明确一下:

星期

长度

Sunday

6

Monday

6

Tuesday

7

Wednesday

9

Thursday

8

Friday

6

Saturday

8

这样的话就清晰了,原因就是周三的字符串长度更长,在这一天,缓冲区恰好溢出了。

这 BUG,还真的就是这么巧妙。

这个 BUG 可能很多同学都知道,也就是几年前的事情。

鸟叔的一首《江南 Style》火遍全球,顺便爆出了 YouTube 的一个 BUG。

原因就是 YouTube 的计数器之前使用的是 32 位整数。32 位整数确定了它可以计数的最大可能点击量为 2,147,483,647。

YouTube 的程序员可能都没想到,还能有一个视频的点击量能超过这个数?

《江南 Style》视频点击量超过了最大值,我们就得到了著名的《江南 Style》YouTube BUG。

现在,YouTube 的视频计数器改用 64 位整数,这意味着视频最大观看人数为 922 万万亿 。

YouTube 程序员:我看看还有谁?

看到这几个 BUG 之后,我的目标就改变了,不再是写出优雅的代码,而是写出巧妙的 BUG。

我要在系统中暗藏一些「奇思妙想」,给我的继任者留下一个又一个惊喜。加油~

以上就是本文的全部内容,如果觉得还不错的话欢迎点赞转发关注,感谢支持。


推荐阅读:

  • 计算机经典必读书籍
  • 技术博客 硬核后端开发技术干货,内容包括 Python、Django、Docker、Go、Redis、ElasticSearch、Kafka、Linux 等。
  • Go 程序员 Go 学习路线图,包括基础专栏,进阶专栏,源码阅读,实战开发,面试刷题,必读书单等一系列资源。
  • 面试题汇总 包括 Python、Go、Redis、MySQL、Kafka、数据结构、算法、编程、网络等各种常考题。