你见过的最糟糕的代码是什么?


来自HackerNews的讨论,其中一个回答非常有趣:
Oracle数据库12.2。
它接近2500万行C代码。
多么难以想象的恐怖!你无法在生产环境下,且需要通过1000次测试的情况下,修改一行代码。几代程序员在困难的期限内却处理了这些代码,并用各种废话填充了代码。
非常复杂的逻辑,内存管理,上下文切换等都与数千个标志一起保存。整个代码都带有神秘的宏,如果没有选择笔记本并且手动扩展相关的宏,就无法破译。可能需要一天到两天才能真正理解宏的作用。
这个产品仍然存活并且仍然有效的唯一原因是通过了数百万次测试!
以下是Oracle数据库开发人员的生活方式:
- 开始处理新的bug。
- 花两周的时间试图了解20种不同的标志,这些标志以神秘的方式相互作用。
- 再添加一个标志来处理新的特殊情况。添加几行代码来检查此标志并解决有问题的情况并避免该错误。
- 将更改提交到包含大约100到200台服务器的测试服务器场,这些服务器将编译代码,构建新的Oracle数据库,并以分布式方式运行数百万个测试。
- 回家。第二天来,继续做其他事情。测试可能需要20小时到30小时才能完成。
- 回家。第二天来,检查你的农场测试结果。在美好的一天,将有大约100个失败的测试。在糟糕的一天,将有大约1000个失败的测试。随机选择一些测试并尝试了解您的假设出了什么问题。也许还有10多个标志要考虑才能真正理解bug的本质。
- 添加一些标志以尝试解决问题。再次提交更改以进行测试。再等20到30个小时。
- 冲洗并重复另外两周,直到你得到组合标志的神秘咒语。
- 最后一天,你会成功,0测试失败。
- 为您的新更改添加一百多个测试,以确保下一个不幸接触这段新代码的开发人员永远不会破坏您的修复。
- 提交最后一轮测试的工作。然后提交以供审核。审查本身可能还需要2周到2个月。所以现在继续讨论下一个bug。
- 在2周到2个月之后,当一切都完成后,代码将最终合并到主分支中。
以上是对Oracle修复bug的程序员生活的非夸张描述。现在想象一下开发新功能会有多么恐怖。开发一个小功能需要6个月到一年(有时是两年!)(比如添加一种新的身份验证模式,比如支持AD身份验证)。
这款产品即使有效,也是一个奇迹!
我不再为Oracle工作了。永远不会再为Oracle工作了!