第504期|程序员容易忽略的8大软件开发定律
卖桃者说
讲述:李佳大小:3.61M时长:03:57
你好,这里是卖桃者说。
前几天,我在 InfoQ 上看到一篇关于软件开发定律的文章,觉得很有意思,所以今天就和你聊一聊。与其他领域一样,软件开发领域也有很多定律,这些定律包括一些法则或软件开发大神的名言,非常经典。接下来,我就和你分享 8 大软件开发定律。
1.康威定律:“任何一个组织在设计一个系统时,这个系统的结构与这个组织的沟通结构是一致的。”这条定律也就是所谓的“按照组织架构来交付软件”。或许你会觉得可以通过一些方式来避免这个定律真正发生,比如采用跨功能团队的站会、进度更新和决策矩阵等等,但这些方法最终都不可避免地会发生冲突和分歧,而这也会影响整个过程和结果。
2.布鲁克定律:“在一个已经延期的项目中增加人手只会让项目延期更长。”这条定律来自《人月神话》。当你意识到项目没有取得预期的进展,并尝试从其他地方调取更多的资源时,不仅会让项目延期,而且更有可能交付一个更脆弱、更复杂的产品。
3.Zawinski 定律:“每一个程序都会膨胀到需要加入 Web 服务器,不膨胀的程序最终会被膨胀的程序所代替。”对 Web 服务来说,就是“膨胀到需要用户账号登录并收集所有用户的数据”;对物理服务来说,就是“膨胀到需要加入一个不安全的 WiFi 访问点,设置了你无法修改的默认密码,以及一个 Web 服务器”。
4.帕金森定律:“一项工作会占用掉所有用来完成它的时间。”也就是说,如果你不给一个项目的里程碑阶段设置截止日期,这个项目就永远完成不了。这就是为什么一定要给一个 MVP(最小可行产品)定一个固定的截止日期。当然,这个定律也可以用在数据、算力、内存等方面,具体来说就是,“程序最终会把所有可用的存储空间、CPU 时间和内存用光”。
5.帕累托谬论:“当你完成了 80% 的工作,你会认为真的只剩下 20% 的工作要做。”这话听上去有点绕,言外之意就是,你很容易低估了剩下的 20% 工作,这些工作很可能占用你 80% 的时间。
6.伊格尔森定律:“你写的任何超过 6 个月没有看过的代码,有可能已经被别人改过了。”其实这条定律里说的 6 个月已经是一个很乐观的数字了,实际日期可能更短。
7.格林斯潘第十定律:“任何一个定制开发的认证系统都包含一个临时的、非正式的、隐藏缺陷的、运行缓慢的 Kerberos 不完整实现。”这条定律通常用在认证方面,也可以概括成一般性的 NIH 规则:“任何一个定制开发的系统都包含一个临时的、非正式、隐藏缺陷的、运行缓慢的行业标准的不完整实现(因为你拒绝直接使用标准实现)”。
8.冰山谬论:“一款新软件的开发成本只占管理层预算的总成本的 25% 左右。”这条定律还延伸出了一句运维界的格言:“如果说软件维护的成本占了总预算的 75%,那么这 75% 都应该是运维支持。”
以上这 8 条经典定律,你对哪条印象最深刻呢?你心中最经典的软件开发定律又是哪条呢?欢迎在留言区一起分享。
卖桃者说,明天见。
(策划:InfoQ;编辑:夏天)
公开
同步至部落
取消
完成
0/2000
荧光笔
直线
曲线
笔记
复制
AI
- 深入了解
- 翻译
- 解释
- 总结
该免费文章来自《卖桃者说》,如需阅读全部文章,
请先领取课程
请先领取课程
免费领取
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
登录 后留言
精选留言
由作者筛选后的优质留言将会公开显示,欢迎踊跃留言。
收起评论