为什么软件开发工期预估都不靠谱

2024-05-01 23:38

本文主要是介绍为什么软件开发工期预估都不靠谱,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文的作者Diego Basch是IndexTank公司(被LinkedIn公司收购)的前任CEO,他是看到了Quora上一个有趣的关于讨论软件开发工期估算不准的文章后写下了这篇文章。

有些人认为做一个大型软件项目跟建一座大桥一样。你可以根据以往的项目,使用那些历史数据来评估所需要的时间和资源。这种观点数十年前就已经被证实为伪观点;这种类比出的结论在上世纪九十年代,我在卡内基·梅隆攻读软件工程学位时,是我一直向往的结果。

现实生活中,大多数值得一做的工程都不会是之前的项目的重复。不要以为当需要一座桥时,你可以“gem install bridge”或扩展bridge4j。一个新的软件项目更像是这样:

— 你是一个发明家。你已经发明了一种太阳能微波炉,一种以死虫子为能量的发动机,一种能杀死蚊子的激光武器。那好,有人找到你对你说:

“嗨,发明家,我需要一种无人机,它能够抓取老鼠(不能是别的动物),定位我的前女友,把老鼠投掷到她头上。给出一个资金预算和工期估计吧。”

很显然,你会不知道如何入手。你需要理解需求。这种东西以前从来没有制造过,但这完全不是什么新技术。无人机已经有了,定技术也有。可是如何能准确的找到老鼠呢?有多少东西是真的需要你去发明的?你可以买一个DIY 无人机,稍加改动是否可以满足需求?你的客户是否能够偷偷的把一个跟踪设备放到他前女友的手袋里?

X-47B 无人机

做软件不是一种重复性动作,而是一种发明性动作。在Twitter上疯传的Quora上的这个奇思妙想的贴子实 际上跑题了。拿从旧金山走到洛杉矶的步行者做类比是不合适的。徒步旅行这项活动已经被人类实践了几千年了,所有你需要的知识只要在谷歌上搜索一下都能找 到。一个苦行僧只要走过一次就能了解所有的行程。当你问他从纽约步行到芝加哥的路程,他很可能相当准确的说出来。经过数次的城际间的旅行后,他有足够的知 识来进行相当准确的估算。但如果我让你告诉我从洛杉矶驾车到旧金山要多少时间,依赖于交通堵塞的状况,你的估算很可能会相差数小时。

而另一方面,如果一个有经验的软件工程师被要求去开发一个能自主驾驶从旧金山到洛杉矶的汽车的控制系统时,他面对的上一种完全不同的情况。真正的软件开发实际是指那些你以前从未做过的东西。这就是为什么所有的这些拿日常真实生活里的东西来做的类比都不靠谱的原因。

[本文英文原文链接:Why Software Development Estimations Are Regularly Off ]

这篇关于为什么软件开发工期预估都不靠谱的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/952952

相关文章

【软件工程】软件开发模型

三、瀑布模型  四、几种软件开发模型的主要特点 题目 判断题 选择题 小结

集成电路学习:什么是SDK软件开发工具包

SDK:软件开发工具包         SDK,即Software Development Kit(软件开发工具包),是一套由软件提供商或其他组织提供的开发工具集合。这些工具旨在帮助开发者更快速、更便捷地创建、测试和部署软件应用程序。以下是对SDK的详细解释: 一、SDK的定义与组成         定义:SDK是一套包含编程工具、代码示例、技术说明文档、调试和测试工具等内容的软件包,有

从知识视角理解软件开发

软件构造中的核心知识:业务知识与架构知识 在软件构造过程中,最关键的两类知识是业务知识和架构知识。业务知识回答“什么是正确的软件”,而架构知识解决“如何正确地构造软件”。从这两个方面深入理解软件构造,可以帮助我们在设计和开发过程中做出更明智的决策。 1. 业务知识:定义正确的软件 业务知识是关于如何解决现实问题的知识,包括业务的目标、规则、限制、和已有的解决方案。它定义了“正确的软件”是什么

第二章 可行性研究与软件开发计划简记

第二章  可行性研究与软件开发计划 可行性研究的任务:回答所开发的软件系统有无可行的解决办法或者这个系统值得开发么。 可行性研究大体可分为三个大的方面:工艺技术、市场需求、财务经济状况。 可行性研究的目的:就是尽可能的用最小的代价在尽可能短的时间内确定问题是否能解决。 可行性研究的解决方案:一般集中在 1.技术可行性2.经济可行性3.操作可行性。

软件工程技术专业软件开发综合实训室解决方案

一、行业背景与前景分析 1.1 软件工程技术专业就业前景 近年来,中国的软件行业取得了显著的成就,即便在全球经济受到新冠疫情冲击的情况下,仍保持了强劲的增长势头。据工业和信息化部发布的数据,2021年我国软件和信息技术服务业的业务收入达到85371亿元人民币,同比增长18.3%,远超同期国内生产总值的增长率。这一成就不仅体现了中国软件行业的韧性和发展潜力,也为未来的持续增长奠定了坚实的基

软件开发教学:基于数字药店系统源码的医保购药APP开发策略

本篇文章,小编将详细探讨基于数字药店系统源码的医保购药APP开发策略,并提出一些开发中的关键技术要点。 一、数字药店系统源码的功能概述 数字药店系统源码是构建在线药店的基础,它集成了药品信息管理、订单处理、支付系统、用户管理等核心模块,旨在实现药品销售的全流程数字化。一个典型的数字药店系统包括以下几个主要功能: -药品信息管理:支持药品分类、库存管理、药品搜索和详细展示。 -订单管理:

一般软件开发流程和一般软件的测试原则

一般软件开发的流程: 软件测试的原则:

为什么单元测试在软件开发中很重要?

单元测试在软件开发过程中扮演着至关重要的角色,其重要性主要体现在以下几个方面: 保证代码质量:单元测试是对软件中的最小可测试单元——函数、方法或类进行检查和验证的过程。通过编写针对各个模块的独立测试用例,开发者能够确保每个单元的功能正确无误,满足预期的行为。这有助于早期发现并修复代码缺陷,提高代码的质量和稳定性,从而降低维护成本和减少后期出现的问题。 促进代码重构与优化:单元测试为代码重构提供

强烈推荐!大模型辅助软件开发

强烈推荐!大模型辅助软件开发 今天给大家推荐一本书----《大模型辅助软件开发》 有感兴趣的小伙伴可以联系我,免费送~ 文末有联系方式嗷~ 太喜欢作者在书上的这句话了:是人类工程师的能力,而不是大模型的能力,决定了大模型协作式开发的上限。 软件开发正在经历一场前所未有的范式变革。人工智能的飞速发展,特别是大型语言模型所取得的成功,不仅会对软件本身的形态产生深远影响,也

软件开发中 的常用加密方式有哪些

在软件开发中,加密技术是保护数据安全的关键手段之一。常用的加密方式可以分为两大类:对称加密和非对称加密。此外,还有散列函数(哈希函数)用于确保数据完整性。下面是一些常见的加密算法和技术: 对称加密算法 AES (Advanced Encryption Standard):高级加密标准,目前最广泛使用的对称加密算法之一。DES (Data Encryption Standard):数据加密标准,