热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

软件开发中的老问题——沟通

软件开发中的老问题——沟通在软件开发中有这样的一个法则(Brook法则):向进度落后的项目中增加人手,只会使进度更加落后。我们经常可
 
软件开发中的老问题——沟通
       在软件开发中有这样的一个法则( Brook 法则):向进度落后的项目中增加人手,只会使进度更加落后。我们经常可以听到“ 1+1>2 ”的说法,但从这个法则中可以知道,在软件开发中1加 1 是小于2的,甚至是小于 1 的,这是为什么呢?其中主要的原因就是沟通,项目开发人员之间的相互沟通产生了额外的时间开销,甚至可能会因沟通而产生新的问题,如新加入的开发人员因对问题理解不全面而导致产生设计上的重大缺陷,使得软件开发变得更加困难。
 
       在《人月神话》中论述了古代巴比伦塔项目建设失败的原因:缺乏交流,以及交流的结果 组织。 因为左手不知道右手在做什么,从而进度灾难、功能的不合理和系统缺陷纷纷出现。 由于对其他人的各种假设,团队成员之间的理解开始出现偏差,最后导致的项目的失败。这里还提到了“组织”建立的几个要素,这些都是非常有意义的,其中有一点给我的印象最为深刻:团队组织的目标是为了减少必要的交流和协作量。当你联系到自己的工作中时,你会发现这种描述是多么的精准,既然沟通会产生额外的代价,那么首先就需要有一个较好的组织,一个较好的组织会减少很多不必要的沟通,减少必要的交流和协作量,也即提高了工作效率。
 
       “沟通,沟通,还是沟通。”每个成熟的程序员或软件项目管理者总会反复地强调这样的问题。那么沟通会有那些形式呢?一般的形式有:非正式、常规项目会议,会上进行简要的技术陈述、共享的正式项目工作手册,以及电子邮件。其中关于项目工作手册我觉得是最为重要的,特别是在大型项目开发中,那是必不可少的,项目工作手册使得沟通在每个项目开发人员中有形无形地在进行着,项目工作手册记录了所有跟开发有关的内容,它保证了项目得以顺利有序地开发。
 
       对于沟通,我觉得还有一种形式是最容易被忽略的,那就是培训,说到培训,一般认为是对新员工的培训,我觉得可以把培训定义得更广泛些:一种学习上的交流。一个开发团队也都有一个相互磨合过程,一个促进磨合的方法是定期进行培训(交流学习),如开发经验的交流、对新技术的理解、工作方式的讨论,把培训做成一种双向交互式的,而非灌输式,应使得大家受益,大家都能够在培训中得到进步。
 
       沟通过程中要注意不要陷入互相扯皮推诿的境地,一个有效的沟通应当是使得开发目标更加明确,开发人员之间的协作更加有效地进行。
 
       最后我们再来看一下进度落后的解决问题,增加新人手,因需要更多的沟通,产生了效率问题,所以在面对这种问题时,我们要适时考虑进度的重新安排,不要把希望寄托在更多的人力上,在增加人手后,最为紧要的问题是如何提高沟通效率,特别是刚开始时应当把沟通列为最为紧要的问题,把因增加人手后产生的负面效应降为最低,我想如果有进行如此地充分周全的考虑和实践是可以达到 1 1 大于或等于 2 的效果的,其实,在很多种情况下能够大于 1 就已经是很不错了。

推荐阅读
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 利用存储过程构建年度日历表的详细指南
    本文将介绍如何使用SQL存储过程创建一个完整的年度日历表。通过实例演示,帮助读者掌握存储过程的应用技巧,并提供详细的代码解析和执行步骤。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文深入探讨了C++对象模型中的一些细节问题,特别是虚拟继承和析构函数的处理。通过具体代码示例和详细分析,揭示了书中某些观点的不足之处,并提供了更合理的解释。 ... [详细]
  • 随着网络安全威胁的不断演变,电子邮件系统成为攻击者频繁利用的目标。本文详细探讨了电子邮件系统中的常见漏洞及其潜在风险,并提供了专业的防护建议。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 深入理解Spring:Aware接口、异步编程与计划任务
    本文将带你深入了解Spring框架中的 Aware 接口、异步编程以及计划任务。通过具体示例和详细解释,帮助你掌握这些核心功能的实现原理和应用场景。 ... [详细]
  • TechStride 网站
    TechStride 成立于2014年初,致力于互联网前沿技术、产品创意及创业内容的聚合、搜索、学习与展示。我们旨在为互联网从业者提供更高效的新技术搜索、学习、分享和产品推广平台。 ... [详细]
  • 网易严选Java开发面试:MySQL索引深度解析
    本文详细记录了网易严选Java开发岗位的面试经验,特别针对MySQL索引相关的技术问题进行了深入探讨。通过本文,读者可以了解面试官常问的索引问题及其背后的原理。 ... [详细]
  • 前端开发:从底层到顶端的行业现象解析
    在编程领域,鄙视链现象屡见不鲜,从C语言到Java、.NET等,每个技术栈都有其独特地位。然而,前端开发者尽管常处于鄙视链底端,却在市场需求中备受青睐。本文深入探讨这一现象,并分析前端工程师如何在竞争激烈的市场中脱颖而出。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • PHP插件机制的实现方案解析
    本文深入探讨了PHP中插件机制的设计与实现,旨在分享一种可行的实现方式,并邀请读者共同讨论和优化。该方案不仅涵盖了插件机制的基本概念,还详细描述了如何在实际项目中应用。 ... [详细]
  • 分享一个简化版的Silverlight链接图项目:Link Map Simplified
    本文介绍了一个使用Silverlight开发的可视化工具,主要用于展示和操作复杂的实体关系图(Graph)。该工具在犯罪调查系统中得到了广泛应用,帮助用户直观地获取和理解相关信息。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
author-avatar
戚敦崩
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有