当前位置: 首页 > news >正文

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

在这里插入图片描述

  人月神话是一篇由美国软件工程师弗雷德里克·布鲁克斯所写的软件工程经典之作,最早发表于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.lryc.cn/news/163337.html

相关文章:

  • 电阻和电容
  • 01-Java-日志框架
  • 【js】map、filter、reduce、fill(待补充...)
  • 【JPC出版】第二届能源与电力系统国际学术会议 (ICEEPS 2023)
  • 51单片机的简易篮球计分器倒计时仿真设计( proteus仿真+程序+原理图+报告+讲解视频)
  • 医院安全不良事件报告系统源码 PHP+ vue2+element+ laravel8+ mysql5.7+ vscode开发
  • Mybatis -- 读取 DATE 类型字段时可能遇到的问题(夏令时问题)
  • 第10节-PhotoShop基础课程-选区工具
  • 【C++】C++动态内存管理
  • Java中使用JTS实现WKT字符串读取转换线、查找LineString的list中距离最近的线、LineString做缓冲区扩展并计算点在缓冲区内的方位角
  • 【异步VS多线程】异步VS多线程区别
  • 【nosql】redis之高可用(主从复制、哨兵、集群)搭建
  • js如何实现数组去重的常用方法
  • XREAL Air 2 Pro发布,加入电致变色技术,拓展AR眼镜使用场景
  • Go基础11-理解Go语言的包导入
  • 【MySQL数据库原理】在MySQL Workbench界面运行SQL代码——学生管理系统
  • 高分三号1米分辨率飞机检测识别数据集
  • Unity 之Material 类型和 MeshRenderer 组件中的 Materials 之间有一些重要的区别
  • 【LeetCode-简单题】977. 有序数组的平方
  • 【笔试强训选择题】Day39.习题(错题)解析
  • Prometheus-Alertmanager 警报管理器-部署和设置
  • 恒运资本:小盘股的优点?投资小盘股要注意哪些方面?
  • LeetCode:2. 两数之和
  • OpenCV(二十四):可分离滤波
  • 【JS进阶】防抖与节流
  • 【css】linear-gradient()的用法
  • java: 读取snakeyaml-1.26.jar各种jar包时出错; error in opening zip file
  • 医疗知识图谱 neo4j
  • 【LeetCode-简单题】367. 有效的完全平方数
  • vben-admin中渲染table表格时怎么处理不同的数据结构