开发者社区 问答 正文

为什么程序员害怕改需求?

4000积分,桌面风扇*6

在复杂多变的软件开发环境中,程序员群体所面临的众多挑战中,有一项尤其令人瞩目,那就是对需求变更的态度。在实际工作中,他们对需求变更的反应却常常带有明显的紧张与谨慎。那么,为什么程序员会对修改需求产生一种普遍的“畏惧感”呢?谈谈你的看法~

本期奖品:截止2024年6月4日24时,参与本期话题讨论,将会选出 3 个优质回答和 3 个幸运用户获得桌面风扇。快来参加讨论吧~

幸运用户获奖规则:本次中奖楼层百分比为12%、42%、68%的有效留言用户可获得互动幸运奖。如:活动截止后,按照回答页面的时间排序,回复为100层,则获奖楼层为 100✖35%=35,依此类推,即第35位回答用户获奖。如遇非整数,则向后取整。 如:回复楼层为81层,则81✖35%=28.35,则第29楼获奖。

优质讨论获奖规则:不视字数多,结合自己的真实经历分享,非 AI 生成。

未获得实物礼品的参与者将有机会获得 10-100 积分的奖励。
桌面风扇.png

注:楼层需为有效回答(符合互动主题),灌水/复制回答将自动顺延至下一层。如有复制抄袭、不当言论等回答将不予发奖。阿里云开发者社区有权对回答进行删除。获奖名单将于活动结束后5个工作日内公布,奖品将于7个工作日内进行发放,节假日顺延。

中奖用户:

优质回答:周周的奇妙编程、梦回故国楼台梦、Freedom123

幸运用户:记得提缸3、鑫宝Code、lian8306

恭喜以上用户!感谢大家对本话题的支持~

展开
收起
提个问题 2024-05-13 11:48:44 1988 分享 版权
134 条讨论
参与讨论
取消 提交讨论
  • 需求一直在变化,而且在开发的过程中的需求都是不固定的。举例:需求方今天说要一个喝水的东西,你给制作了一个水杯。明天他又觉得东西太小了,得变大;后天又觉得太单一需要丰富一点...

    2024-06-03 10:22:22
    赞同 28 展开评论 打赏
  • 原因:要求在不合理的短时间内完成。

    程序员害怕的是今天提明天要、短期突击的需求,不单单程序员害怕所有人都害怕。如果需求修改后,不要求完成时间,随便什么时间完成都可以,我猜没有程序员会害怕。

    程序员怕的是不讲理:活儿变了时间不变,这么搞换谁都害怕。

    这样搞谁顶得住呀...

    2024-05-31 16:45:22
    赞同 29 展开评论 打赏
  • 一改需求很多写好的就要重新写,真的很烦啊,加大了时间与资源的投入:软件开发是一个复杂的过程,通常需要大量的时间、人力和资源投入。一旦需求发生变更,可能意味着之前的努力和投入需要重新评估,甚至可能需要推倒重来,这无疑会增加项目的时间和成本。
    而且计划的破坏:软件开发项目通常有严格的时间表和里程碑。需求的变更往往会打乱原有的计划,导致项目延期,这可能会对团队成员造成压力,尤其是项目经理和客户。

    这谁受的了啊

    2024-05-31 16:05:20
    赞同 30 展开评论 打赏
  • 阿里云大降价~

    正开发着,好不容易差不多写好了,需求一改,得了,方法重新写,活白干,这谁不气啊
    。。。
    还有就是质量风险:频繁的需求变更可能导致软件质量下降。程序员需要在满足新需求和保持软件质量之间找到平衡。
    另外对变化的抗拒:人们通常对变化有自然的抗拒感,程序员也不例外。他们可能更愿意坚持原有的计划,而不是不断适应变化。

    2024-05-31 12:10:00
    赞同 28 展开评论 打赏
  • 需求变更可能会导致项目进度延期,影响交付日期,这会给程序员带来额外的压力,可能需要增加更多的加班时长,所以会比较抗拒和害怕

    2024-05-30 11:02:40
    赞同 28 展开评论 打赏
  • 当程序员已经投入大量时间和精力完成某个功能时,需求变更可能意味着他们之前的努力至少部分上白费了。
    需求变更往往伴随着额外的工作量,这可能导致程序员需要加班,影响他们的工作生活平衡。

    2024-05-30 10:59:45
    赞同 28 展开评论 打赏
  • 对于我们来说,最主要就是担心频繁的需求变更会导致代码不断修改和重构,增加维护和测试的难度,使系统变得复杂而难以维护。

    2024-05-30 10:59:48
    赞同 25 展开评论 打赏
  • 为什么程序员害怕改需求?
    需求变更可能涉及到系统的核心逻辑和架构的改变,这对程序员来说是一项技术挑战。他们需要评估变更对现有代码的影响,进行重构或修改,保证系统的稳定性和可靠性。复杂的技术实现可能需要更多的时间和精力,而程序员担心自己无法应对这种复杂性,或者无法在有限的时间内完成任务。

    2024-05-30 10:59:46
    赞同 23 展开评论 打赏
  • 首先,软件开发是一个系统工程,各模块紧密耦合在一起。改需求可能需要全面调整已有设计与实现,给日常工作带来很大影响。

    其次,我们开发任务安排的一个重要考量是时间成本和进度。而改需求很难事先评估工作量,可能会延迟原计划。

    此外,软件质量也是一个难点。架构设计和开发过程都基于既有需求,而需求变动很难保证不同版本兼容性和稳定性。

    再者,客户需求的优先级和决定难以判断。收到要求需详细沟通和分析,这对开发效率的影响也不容小觑。

    最后,改需求绝不等同于新需求。它修改了我们熟悉的工作模式,需要更多时间掌握新变化,这对心理也是一种考验。

    总体来说,改需求给开发带来很多额外的成本和挑战性。我们需要与客户保持密切沟通,给予充分的改动时间,以减轻程序员的这种“畏惧感”。

    2024-05-30 10:59:46
    赞同 17 展开评论 打赏
  • 最主要的原因我觉得是已经编写和测试过的代码需要进行修改,这可能引入新的错误,影响系统的稳定性和性能。

    2024-05-30 10:59:47
    赞同 15 展开评论 打赏
  • 改需求无异于增量开发,给代码质量和进度控制带来一定风险。

    2024-05-30 10:53:29
    赞同 9 展开评论 打赏
  • 为什么程序员害怕改需求?
    影响进度和计划:改变需求通常会引起开发计划的变动,可能导致项目延迟或者增加额外的工作量。程序员可能害怕无法按时完成任务或者无法控制项目的进度。
    资源限制和工作量增加:改变需求可能需要额外的资源和工作量,包括时间、人力和技术资源。程序员可能担心无法满足新需求的要求,或者需要加班或压缩原本的工作进度。
    技术挑战和不确定性:新需求可能涉及到新的技术或者复杂的问题,程序员可能担心自己没有足够的技术能力或知识来解决这些挑战。此外,新需求可能带来不确定性,程序员可能担心无法准确预测和评估新需求的影响。
    代码稳定性和质量:改变需求可能涉及到代码的修改和重构,程序员可能担心修改代码会引入新的错误或者破坏现有的代码稳定性。他们可能担心无法保证修改后的代码质量和系统的稳定性。
    没有清晰的需求文档或沟通不畅:如果需求的变动没有明确的文档或者沟通不畅,程序员可能会感到困惑和不确定。他们可能担心无法准确理解需求的变动,导致错误的实现或者不满足用户的期望。

    2024-05-30 10:53:29
    赞同 7 展开评论 打赏
  • 改动范围大可能会影响其他功能模块,需要花时间回归测试。
    改需求容易超出原计划时间成本,可能需要加班赶工,给自己带来压力。

    2024-05-30 10:51:22
    赞同 6 展开评论 打赏
  • 恐惧,恐惧这些变更带来的影响,比如工作量加大,加班加点,延期交付,bug数变多等

    2024-05-30 10:51:22
    赞同 4 展开评论 打赏
  • 为什么程序员害怕改需求?
    新需求可能涉及到新的技术或者复杂的问题,程序员可能担心自己没有足够的技术能力或知识来解决这些挑战。此外,新需求可能带来不确定性,程序员可能担心无法准确预测和评估新需求的影响。

    2024-05-30 10:47:04
    赞同 5 展开评论 打赏
  • 这是人之常情,不只是存在于程序员这个群体,人们通常倾向于完成已经开始的工作,改变方向会引起心理上的抗拒。

    2024-05-30 10:40:37
    赞同 5 展开评论 打赏
  • 为什么程序员害怕改需求?
    改需求意味着原有设计与实现可能要重新修改,给代码结构增加风险。
    需要花时间重新学习需求细节,修改已有功能可能会出Bug或缺页。

    2024-05-30 10:40:37
    赞同 5 展开评论 打赏
  • 大部分的原因是改需求可能会破坏之前的代码设计,导致更多的工作量,就像造一座桥一样,一开始设计图纸是造桥的图纸,工人已经造好了地基,忽然说要造楼房了,那地基不就可能需要全部重来了吗

    2024-05-30 10:38:06
    赞同 5 展开评论 打赏
  • 主要是觉得自己前期的工作可能会付之东流,会觉得很气愤,还有就是需求变更之后的影响,比如工期的延长等,所以会比较抗拒这种

    2024-05-30 10:34:43
    赞同 4 展开评论 打赏
  • 我觉得主要有以下几个原因:
    1维护成本高:需求改变通常意味着需要修改已经完成的代码,这会增加维护成本。程序员需要花时间理解原有代码结构和业务逻辑,然后进行相应的修改和调试,非常耗时耗力。
    2破坏原有设计:需求的改变可能会违背原有系统的设计原则和架构模式,需要重构大量代码。这会增加系统的复杂度,降低代码的可读性和可维护性。
    3质量保证困难:修改代码后很难完全确保不会引入新的bug,尤其是在大型复杂系统中。程序员担心会在修复一处问题的同时,在其他地方引发新的问题。
    4时间压力:需求改变通常伴随着紧迫的上线时间,程序员需要在有限的时间内完成设计、开发和测试工作,增加了工作强度。
    5责任担忧:如果需求改变后出现严重的系统问题,程序员担心会受到问责。这种责任压力使得他们更加谨慎,不愿意轻易接受改需求的要求。

    2024-05-30 10:23:54
    赞同 5 展开评论 打赏
滑动查看更多
问答分类:
问答地址:
话题讨论榜
  • 1
    人脸识别“进化”,你最感兴趣的使用场景有哪些?
    奖品池:4000积分,运动水壶*5
    70

    在人脸识别技术飞速发展的背景下,确实有许多令人感兴趣的使用场景,并且这些场景不仅展示了技术的进步,也体现了其在实际应用中的巨大价值。以下是一些我认为特别有趣且具有重要价值的应用场景: 1. 智慧医疗 应用场景:通过人脸识别技术,医院可以实现患者身份的快速验证,减少挂号、就诊过程中的等待时间。此外,在远程医疗服务中,人脸识别还可以帮助确认患者身份,确保服务的安全性和准确性。 体现的价值:提高了...

  • 2
    如何让PB级日志数据也能实现秒级分析?
    奖品池:4000积分,创意抱枕*5
    56

    要让PB级日志数据实现秒级分析,可从以下几个方面着手: 数据存储与管理 分布式存储:采用Hadoop分布式文件系统(HDFS)等分布式存储系统,将数据分散存储在多个节点上,可实现高可扩展性和容错性,支持PB级数据存储。 数据分区与索引:对日志数据按时间、类别等维度进行分区,建立高效的索引结构,如倒排索引,能快速定位和检索数据,减少查询范围,提高查询速度。 分析工具与技术 分布式计算框架:运用...

  • 3
    MCP Agent是如何加速AI应用或工作流的开发?
    奖品池:4000积分,定制马克杯*5
    34

    MCP Agent加速AI应用开发的核心价值体现在标准化连接和智能化协作上啦!首先,它通过统一通信协议(类似“万能插座”)让AI模型轻松对接各种工具,比如数据库、地图API等,开发者无需为每个工具单独写代码,直接调用现成服务就行。比如阿里云百炼平台集成高德地图后,5分钟就能搭建旅游规划Agent,整合路线和天气信息,效率直接翻倍哦! 其次,MCP支持跨步骤上下文保存,让AI像人一样记住之前的...

  • 4
    职场钝感力,是“反抗”还是“妥协”?
    奖品池:4000积分,桌面收纳盒*4
    60

    职场钝感力是一个近年来被频繁讨论的概念,它并非字面意义上的“迟钝”或“麻木”,而是一种基于理性思考的自我保护能力,旨在帮助个体在复杂的职场环境中保持稳定心态,避免过度消耗情绪。这种能力的核心在于对外界干扰的“选择性屏蔽”,以及对自我价值的清晰认知。 职场中,许多人容易被同事的评价、领导的情绪、短期的挫折或人际关系的波动所困扰。以个人经历来说,这两年的全国大环境不是很好,企业普遍存在降薪、裁员...

  • 5
    你定义的 AI 编码规则是什么?全网寻找通义灵码 Rules {头号玩家}!
    奖品池:4000积分,Cherry 无线双模鼠标*1
    42

    1.如何配置 Project Rules? 官方已经给出了很详细的配置方法,基本上都是一个套路,在IDE编辑器的设置页面里找到Lingma->AI规则->启用->编辑,输入你要配置的内容,即可配置成功,如下图所示: 2.Project Rules 你是一名资深全栈Python工程师,严格遵循PEP8规范,精通DRY/KISS/YAGNI原则,熟悉OWASP安全最佳实践。擅长将任务拆解为最小单...

  • 还有其他疑问?
    咨询AI助理