【人月神话】重新探索人月神话:软件工程的现实与挑战

news2025/1/11 14:16:14

在这里插入图片描述

  人月神话是一篇由美国软件工程师弗雷德里克·布鲁克斯所写的软件工程经典之作,最早发表于1975年。这篇文章的全名是《人月神话:软件工程的神话与现实》(The Mythical Man-Month: Essays on Software Engineering),它涵盖了布鲁克斯在IBM公司参与OS/360操作系统开发过程中的经验和观察


📕作者简介:热爱跑步的恒川,致力于C/C++、Java、Python等多编程语言,热爱跑步,喜爱音乐的一位博主。
📗本文收录于恒川的日常汇报系列,大家有兴趣的可以看一看
📘相关专栏C语言初阶、C语言进阶系列、恒川等,大家有兴趣的可以看一看
📙Python零基础入门系列,Java入门篇系列、docker技术篇系列、Apollo的学习录系列正在发展中,喜欢Python、Java、docker的朋友们可以关注一下哦!

重新探索人月神话

  • 1. 人月神话的来历和观点
  • 2. 读人月神话的意义
  • 3. 推荐好书《人月神话》

1. 人月神话的来历和观点

  人月神话是一篇由美国软件工程师弗雷德里克·布鲁克斯所写的软件工程经典之作,最早发表于1975年。这篇文章的全名是《人月神话:软件工程的神话与现实》(The Mythical Man-Month: Essays on Software Engineering),它涵盖了布鲁克斯在IBM公司参与OS/360操作系统开发过程中的经验和观察。

  文章的标题“人月神话”源自于当时操作系统开发的一个误区,即认为投入更多的人力资源就可以在更短的时间内完成项目。布鲁克斯指出,对于某些任务,增加人力资源并不能显著加速工作进程,反而可能导致时间延误和沟通困难。他将这种误区形象地比喻为“将九个女人放在一起,使之在一个月内生下一名婴儿”的荒谬情景。

  在《人月神话》中,布鲁克斯还提出了一系列软件工程中的重要原则和经验教训。其中一些重要的观点包括:

  1. 布鲁克斯提出的“人月理论”认为,在某些情况下,增加项目成员反而可能导致工作效率下降。这是因为新成员需要时间去适应项目,而且沟通和协调成本也会增加。他建议通过增强团队合作和提高沟通效率来解决这个问题。
  2. 文中讨论了软件工程中的“复杂性”问题。布鲁克斯认为,软件开发的复杂性是不可避免的,而且随着项目规模的增加会呈指数级增长。他呼吁工程师采用模块化和抽象化的方法来降低系统复杂性,并提出了“无玻璃屋”原则,鼓励项目成员之间进行开放、透明和频繁的沟通。
  3. 布鲁克斯还介绍了一些项目管理和团队组织方面的经验教训,包括“饲料链”概念,即将一名经验丰富的软件工程师指定为项目负责人,以确保项目的顺利进行。

2. 读人月神话的意义

  《人月神话》成为了软件工程领域的经典著作,对后来的软件开发和项目管理实践产生了广泛的影响。布鲁克斯从自己的经验中总结出的观点和原则,为软件工程师提供了宝贵的指导和启示。尽管该书最初出版于上世纪70年代,但其中的许多观点和原则至今仍然适用,对于理解和应对软件工程中的挑战仍然具有重要意义。

  人月神话是一种广为流传的说法,常用来形容在软件开发过程中的时间和资源管理问题。这个神话源自于软件工程师弗雷德·布鲁克斯的经典著作《人月神话》。

  在《人月神话》中,布鲁克斯提出了一个观点:在软件开发过程中,增加人力资源并不能缩短项目的时间。他认为,软件开发是一项复杂的任务,需要团队成员之间的协作和沟通。增加人力资源可能会导致更多的沟通和协调问题,从而延长项目的时间。

  布鲁克斯还提到了另一个重要的观点:时间是无法压缩的。他认为,如果一个项目已经被延迟了,再增加人力资源也无法弥补已经损失的时间。因为新加入的人员需要时间来熟悉项目,而且他们的加入可能会导致更多的沟通和协调问题。

  人月神话的核心观点是,软件开发是一项复杂的任务,不能简单地通过增加人力资源来加快项目进度。相反,更重要的是优化团队的协作和沟通,以及合理规划项目的时间和资源。

  然而,人月神话并不是绝对的真理。在某些情况下,增加人力资源可能会带来一定的效果,特别是在项目初期或者是一些简单的任务中。但是,在大多数情况下,人月神话提醒我们要谨慎对待增加人力资源的做法,而应该更加注重团队的协作和沟通,以及合理规划项目的时间和资源。

3. 推荐好书《人月神话》

在这里插入图片描述
内容摘要
  在软件领域,很少能有像《人月神话》一样具有深远影响力和长销不衰的著作。布鲁克斯博士为人们管理复杂项目提供了颇具洞察力的见解,从宏观角度有层次地分析了软件工程的方方面面,不仅逻辑严谨,而且颇具文化底蕴。本书内容主要来自布鲁克斯博士在IBM公司研发并管理System/360计算机家族和OS/360软件支持包期间的项目管理经验,该项目堪称软件开发项目管理的典范。

  本书英文版一经面世,即引起业内人士的强烈反响,后译为德、法、日、俄、中、韩等多种文字,成为软件开发和管理人员的必读经典。

购买链接:人月神话

作者简介
  小弗雷德里克·P.布鲁克斯(Frederick P.Brooks,Jr.1931-2022),图灵奖得主、美国国家科学院院士,对计算机体系结构、操作系统和软件工程做出里程碑式贡献的计算机科学家。
在这里插入图片描述

  布鲁克斯博士于20世纪60年代初主持与领导了被称为人类从原子能时代进入信息时代的标志的IBM/360系列计算机的开发工作,取得辉煌成功,被认为是“IBM360系统之父”。布鲁克斯博士创立了北卡罗来纳大学的计算机科学系,并于1965-1985年担任系主任。他还曾任职于美国国家科技局和国防科学技术委员会。

  布鲁克斯博士作为硬件和软件的双重专家和出色的教育家始终活跃在计算机舞台上,因其专业成就和对计算机体系结构的卓越贡献而屡获表彰,包括美国国家技术奖、ACM杰出服务奖、ACM Fellow、ACM Newell奖、IEEE McDowell奖、计算机先驱奖、冯·诺伊曼奖、富兰克林学会鲍尔奖、图灵奖等。


  如果这份博客对大家有帮助,希望各位给恒川一个免费的点赞👍作为鼓励,并评论收藏一下,谢谢大家!!!
  制作不易,如果大家有什么疑问或给恒川的意见,欢迎评论区留言。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/971111.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

智慧导览|智能导游系统|AR景区导览系统|景区电子导览

随着文旅市场的加快复苏,以及元宇宙、VR、AR、虚拟数字人等新兴技术的快速发展,文旅行业也正在加快数字化转型的步伐,向智慧景区建设迈进。为满足不同年龄段游客的游览需要,提升旅游服务体验,越来越多的旅游景区、博物…

BlueStore BlueFS rocksdb 关联性梳理

Tag: ceph 12.2.4 BlueStore空间初始化 BlueStore磁盘空间管理 总述 OSD挂载目录基于文件系统管理,Slow、WAL、DB空间区域基于裸盘管理;Slow区域:此类空间主要用于存储对象数据,由BlueStore管理,其中分配于BlueFS空…

如何将枯燥的大数据进行可视化处理?

在数字时代,大数据已经成为商业、科学、政府和日常生活中不可或缺的一部分。然而,大数据本身往往是枯燥的、难以理解的数字和文字,如果没有有效的方式将其可视化,就会错失其中的宝贵信息。以下是一些方法,可以将枯燥的…

Python入门 类class 基础篇

记住一句话:类是模板,而实例则是根据类创建的对象。 我初学时对类的理解是从类的字面上,可以片面的认为它是一个种类,它是相似特征的抽像,也就是相似的东西,可以把相似特征的事务抽象成一个类。&#xff0…

基于串口校时的数字钟设计

文章目录 设计目标硬件设计数码管串口 软件设计顶层模块串口接收模块数据处理模块时钟模块串口发送模块 总结 设计目标 环境:ACX720开发板 实现功能: 数码管能够显示时分秒能够接收串口数据修改时间能够将当前时间以1s一次速率发送到电脑 硬件设计 数…

java之SpringBoot基础篇、前后端项目、MyBatisPlus、MySQL、vue、elementUi

文章目录 前言JC-1.快速上手SpringBootJC-1-1.SpringBoot入门程序制作(一)JC-1-2.SpringBoot入门程序制作(二)JC-1-3.SpringBoot入门程序制作(三)JC-1-4.SpringBoot入门程序制作(四)…

virtualbox 扩展磁盘大小

此处设置完成后,还需要进入虚拟机,实际扩展磁盘大小 参考 https://zhuanlan.zhihu.com/p/319431032

搭一个shinyAPP就是一篇《Bioinformatics》?

写在前面 原本想引用一番shiny,结果并没有检索出shiny研发团队所发表的论文,倒是有诸多shiny爱好者搭建shinyApp所发表的文章。例如这篇题为“ShinyGO: a graphical gene-set enrichment tool for animals and plants”、于2020年发表于《Bioinformatic…

【AWS】如何用SSH连接aws上的EC2实例(虚拟机)?

目录 0.环境 1.连接结果示例 2.SSH连接思路 3.具体步骤 1)安装并运行ssh服务 2)启动ssh服务 3)在AWS上找到正在运行的EC2实例,并且根据提供的ssh连接语句进行连接 0.环境 windows 11 64位 前提: 有aws账户&…

B. Swap and Reverse

Problem - B - Codeforces 思路:这个题想复杂了,对于第一个条件,我们发现其实就是可以对所有的奇数位置之间任意交换,所有的偶数位置之间任意交换,对于第二个条件来说,如果k为奇数是没有意义的,…

2022年12月 C/C++(七级)真题解析#中国电子学会#全国青少年软件编程等级考试

C/C编程(1~8级)全部真题・点这里 第1题:走迷宫 一个迷宫由R行C列格子组成,有的格子里有障碍物,不能走;有的格子是空地,可以走。 给定一个迷宫,求从左上角走到右下角最少需要走多少步…

跑得快的快递和跑得慢的快递差在哪些环节?

快递速度是现代物流的核心竞争力之一,对于电商行业和消费者而言,快捷、高效的快递服务意味着更好的购物体验和更高的客户满意度。大家都有过这样的经历:有时候我们选择了跑得快的快递公司,包裹几乎可以说是眨眼间就到达了目的地&a…

​SIGIR 2023 | 用于序列推荐的多兴趣预训练框架

©PaperWeekly 原创 作者 | 唐作立 单位 | 武汉大学硕士生 研究方向 | 推荐系统 引言 在推荐系统中,由于用户具备多种兴趣的特点,使用多兴趣学习(Multi-interest Learning)对用户进行建模能够带来显著的性能提升,…

【2023集创赛】加速科技杯二等奖作品:基于ATE的电源芯片测试设计与性能分析

本文为2023年第七届全国大学生集成电路创新创业大赛(“集创赛”)加速科技杯二等奖作品分享,参加极术社区的【有奖征集】分享你的2023集创赛作品,秀出作品风采,分享2023集创赛作品扩大影响力,更有丰富电子礼…

自然语言处理 微调大模型ChatGLM-6B

自然语言处理 微调大模型ChatGLM-6B 1、GLM设计原理2、大模型微调原理1、P-tuning v2方案2、LORA方案 1、GLM设计原理 bert的主要任务是随机的去除掉某个单词,使用上下文将其预测出来(相当于完形填空任务); GPT的主要任务是根据前…

idea配置gitLab

前言:网上有很多类似的文章,但描述不够详细 步骤1:安装git 如果安装成功再次点击TEST按钮展示如下:git版本 步骤2:idea配置gitlab 查看当前项目管理的 远程仓库再git的地址,该地址可是gitLab的&#xff0…

基于sonar 的C#静态代码扫描使用总结

1.原理简介 C#语言接入Sonar代码静态扫描相较于Java、Python来说,相对麻烦一些。Sonar检测C#代码时需要预先编译,而且C#代码必须用MSbuid进行编译,如果需要使用SonarQube对C#进行代码质量分析,则需要Sonar-Scanner-MSBuild和MSBu…

WorldCoin 运营数据,业务安全分析

WorldCoin 运营数据,业务安全分析 Worldcoin 的白皮书中声明,Worldcoin 旨在构建一个连接全球人类的新型数字经济系统,由 OpenAI 创始人 Sam Altman 于 2020 年发起。通过区块链技术在 Web3 世界中实现更加公平、开放和包容的经济体系&#…

PHP 影院售票管理系统Dreamweaver开发mysql数据库web结构php编程计算机网页代码

一、源码特点 PHP 影院售票管理系统是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 https://download.csdn.net/download/qq_41221322/88297676 PHP 影院售票管理系统Dr…

OpenCV(十九):模板匹配

1.模板匹配: OpenCV提供了一个模板匹配函数,用于在图像中寻找给定模板的匹配位置。 2.图像模板匹配函数matchTemplate void matchTemplate( InputArray image, InputArray templ, OutputArray result, int method, InputArray mask noArray() ); image…