`
ningboxiao
  • 浏览: 30729 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

提升团队编码效率的几条经验

阅读更多

1. 定义好团队结构

可以按照多种方式来定义团队结构,不过最常见的两种是主程序员团队与无我编程团队。

主程序员团队至少由3人组成:一个主程序员、一个高级程序员和一个程序管理员。这种结构非常适合于处理简单和直接的任务。另一方面,该结构并不适合于复杂的任务,因为在这种结构下,交流与任务协作都是非常有限的。

无我编程通常是个去中心化的团队,由10个左右的程序员构成。整个团队会共同参与设定目标,在项目的不同阶段,领导者也会发生相应的变化,这会提升工作满意度。除此之外,良好的协作与交流也使得这种结构非常适合于处理复杂任务。不过另一方面,缺乏控制可能会造成效率与生产力的下降。

2. 将项目分解为任务

在定义好团队角色后,接下来需要将项目分解为任务,并将这些任务分派给团队成员。好的做法是一个团队成员只负责一个任务。如果需要,可以将一个任务分解为几个更小的任务,这样可以很好地完成。

3. 制订项目计划

定义好团队结构并分派好任务后,接下来就需要制订项目计划了。在这个阶段,你需要确定好任务的优先级与顺序,同时还要指定好每个任务的截止日期,这样才能确定下来整个项目的持续时间。

这个过程可以通过传统手段完成:使用笔纸。不过,最好使用项目管理软件来做。这样不仅会加快计划的速度,而且现在有很多在线工具可以实现跨团队成员的沟通与协作。

在这个阶段中需要考虑到的一个重要的事情就是计划谬误——低估完成任务所需的时间。这种心理现象只会影响到我们对自己所要做的任务的预测。在1994年的一项研究中,研究人员让学生们估算一下他们完成论文所需的时间,平均的估算时间是33.9天,而实际完成的平均时间则是55.5天。因此,好的做法是将估算时间乘以1.7,这样才会得到一个比较恰当的估算时间。

4. 定义编码标准

不同的程序员有着不同的编码风格,这会导致低效的编程和错误修复过程。幸好,我们可以通过定义团队中每个人都要使用和遵守的编码标准来轻松解决这个问题。最好的做法不是强制施加标准,而是团队一同来制订标准,根据业界的最佳实践与推荐来制订。

5. 不要编辑现有代码

这个提示是对上一提示的补充,并且在编码标准尚未形成的情况下尤为重要。当团队中存在着不同的编码风格,同时又没有定义好编码标准时,经常出现的一种情况就是一个人会重写其他人的代码,觉得自己的代码风格是最好的。这会扰乱团队成员之间的关系,降低大家对工作的满意度,并且将大量宝贵的时间浪费在没什么生产力的事情上面。因此,建议大家不要这么做,如果怀疑或是发现有人这么做时要及时提出来。

6. 考虑结对编程

结对编程是一种特别的开发技术,指的是两个程序员在一台电脑前工作的方式。其中一个程序员编写代码,另一个程序员会审查他所编写的每一行代码。两个程序员的角色会频繁切换。

相较于独立工作的方式,结对编程有很多优势。两个程序员共同编写出的代码Bug更少,完整性更好,能够更快地找出问题的解决方案并提供更多的设计选择。除此之外,结对编程还会提升生产力,因为处于结对中的程序员不太可能频繁检查社交网络、邮件或是在工作时间内上网。

另一方面,有一些情况会破坏结对编程的效率:

  • 脱离(其中一个成员没在工作,离开了计算机)。
  • 一个程序员的经验比另一个少很多,他总是看自己的同伴写代码。
  • 程序员彼此之间缺乏交流和沟通。应该极力监控和避免这些情况的发生。

7. 使用版本控制软件

老话说的好“只要做就有可能出错”,编程的时候当然也会出现错误。然而,如果没有使用版本控制软件,那么团队成员可能就要花很多时间将代码恢复到之前没有错误的状态。借助于版本控制软件,恢复的过程就好比是按下一个撤销按钮一样简单。

8. 不要在延迟的项目中再添加人手

“在延迟的软件项目中添加人手会让项目更加延迟”,这句话出自Brooks之口。更加通俗一点,“9个女人不能在1个月内生出孩子”。那么,为什么说添加更多的人手反而会导致效率低下呢?主要的原因在于新人需要时间才能实现高效率。这个时间又叫做增强时间,涉及到对新人的培训,让其了解项目之前的工作、目标与细节信息。资深的团队成员要花很多时间在培训而不是工作上,这意味着放在项目任务上的资源就变得更少了。然而,这只适用于那些已经延迟了的项目。

9. 不要加班

当项目延期时,经理们通常会要求团队成员加班来完成工作。这么做会导致精力衰竭、动力降低、工作满意度下降的结果。此外在加班时,人的生产力实际上是很低的。因此,不要加班,而是在工作时间内保持高效率。

10. 工作时保持舒服的感觉

在编程时,重要的是要保证大脑运转正常,不要被其他事情分心。比如说保持足够的睡眠、在工作前做一些轻度的运动或是吃点东西都会提升工作效率。另外,一把舒适的椅子、明亮的灯光等都有助于大脑的全神贯注。

64
5
分享到:
评论
9 楼 net_hare 2014-02-14  
结对编程在现实中需要平衡考虑。如果两人水平太悬殊就变成师傅带徒弟了,对任务完成并没有预期的结构。感觉应该分层、分队;高低搭配,既能体现结对编程的优势,又能对提高低水平程序员的技能。
8 楼 MrLee23 2014-02-13  
liqi756856 写道
结对编程我第一次听说  很新颖的感觉  以后尝试一下

结对编程相当效率,本人亲身体验过。
但是这个要求要高一些,两个人必须目标一直,其中一个要是有懒惰或是不负责人的态度的话,那就糟糕了,总得来说就是必须两个人都是有责任感,并且关系要相处的很融洽才可以,而且编码的水平要尽量的持平,不能相差太悬殊。本人的感悟。
7 楼 yixiandave 2014-02-11  
基层程序员表示对第四条深感赞同
6 楼 liqi756856 2014-02-11  
结对编程我第一次听说  很新颖的感觉  以后尝试一下
5 楼 minimu 2014-02-11  
理论是丰满的,现实是骨感的
4 楼 mfkvfn 2014-02-11  
zhu19880819 写道
说的非常好,特别是第5条和第8条是很多人和管理人员最容易犯的错误。

第9条和第8条吧
3 楼 naily 2014-02-11  
总结的这十条非常不错,深有感触!
2 楼 xiaohuafyle 2014-02-10  
说得比较好,结队编程这个概念我还是第一次听说
1 楼 zhu19880819 2014-02-10  
说的非常好,特别是第5条和第8条是很多人和管理人员最容易犯的错误。

相关推荐

    服务端架构师职位描述与岗位职责.pdf

    3. 深入思考和解决研发过程中的问题,提升团队工作效率和开发质量。 4. 引入新技术和新方案以适应业务的实际需求。 5. 负责跨团队的重点项目推进,展示优秀的项目管理和沟通协调能力。 对于服务端架构师的任职要求...

    编码规范 C#编码规范

    本文档旨在为C#开发人员提供一套统一的编码标准,以提高代码的质量并促进团队协作。这份思远+1的C#编码规范适用于所有使用C#语言进行开发的项目。 #### 编码原则 - **一致性**:所有的开发人员都应该遵循相同的...

    如何提高自己的编程能力 丰富的想象力

    ### 如何提高自己的编程能力——丰富的想象力 #### 扎实的基础是编程的起点 在成为一名优秀的程序员的路上,首先要做的是打下坚实的基础。这不仅包括掌握计算机科学的基本原理,还要熟悉数学基础知识,如离散数学...

    JAVA开发编码规范1.2(1).doc

    目的通常是为了提高代码质量,降低维护成本,提高团队间的沟通效率。范围则明确指出这份规范适用于所有Java项目的源代码编写。 **1.1 目的** 规范的主要目的是通过定义一套通用的代码书写规则,使代码易于理解、...

    C语言 编码规范 供参考.pdf

    这些规范的遵循不仅能够确保开发环境的一致性和可预测性,还能够提升软件工程中代码的质量和团队合作的效率。在实际的软件开发过程中,合理应用这些规范,将对项目的长期维护和扩展带来积极影响。

    软件编码规范

    ### 软件编码规范详解 #### 1. 引言 ##### 1.1 编写目的 本文档旨在为“******公司”的研发部门制定...这套规范不仅有助于提升代码的质量和可维护性,还能促进团队成员之间的沟通与协作,进而提高整个团队的开发效率。

    java编码规范

    以上规范是Java编码实践的基础,旨在通过标准化流程和高质量代码标准,提升软件项目的整体质量和开发效率。遵循这些规范不仅能够提高个人编程技能,还能促进团队协作,最终实现软件产品的卓越表现。

    c#编码规范.pdf

    ### C# 编码规范详解 #### 一、编写目的 C# 编程语言作为.NET平台上的一种重要的编程工具,在软件开发过程中扮演着至关重要的角色。...遵循这些规范不仅有助于提高个人编程水平,还能有效提升团队合作效率。

    JAVA编码规范.doc

    **JAVA编码规范** Java编程规范是为确保代码的可读性、可维护性和团队协作的一致性而设立的一套规则和指导原则。...在实际开发中,不断实践和改进这些规范,可以使团队的工作流程更加顺畅,提升整体的开发效率。

    《敏捷教练之路》演讲PPT

    ScrumMaster是负责引导团队遵循Scrum流程、清除阻碍团队前进的障碍并帮助团队提高效率的敏捷教练。 3. 持续集成(Continuous Integration, CI) 持续集成为开发团队频繁地将代码变更合并到共享仓库中的实践。它允许...

    《软件编码规范说明书》1

    《软件编码规范说明书》是指导程序员编写高质量代码的重要文档,旨在提高代码的可读性、可维护性和团队协作效率。编码规范主要涵盖以下几个方面: 1. **代码缩进**:为了保持代码的清晰和整洁,编码规范规定了使用...

    Java语言编码规范

    ### Java语言编码规范详解 #### 1. 引言 (Introduction) ##### 1.1 为何需要编码规范 (Why Have Code Conventions) 在软件工程领域,编码规范的...遵循这些规范不仅可以提升代码的质量,还能提高团队协作的效率。

    为什么越来越多的组织和个人选择了敏捷?.pdf

    敏捷的12条原则进一步阐述了如何实现这些价值观,例如:欢迎需求变更,即使在开发后期;定期交付可工作的软件,交付频率可以是几周或几个月;业务人员和开发人员必须每天一起工作,以便更好地理解需求和解决问题;...

    对编程者的忠告!!!!!

    以下是对编程者的几条关键忠告,旨在帮助大家更高效、更专业地从事编程工作。 ### 1. 持续学习,保持好奇心 编程领域的知识更新迅速,新技术、新框架层出不穷。作为程序员,持续学习是提升自我、适应变化的关键。...

    Rios公司敏捷开发分享资料

    "敏捷宣言"是敏捷开发的基石,它由四条价值观和十二条原则构成,旨在提高开发效率,提升软件质量。 1. 敏捷价值观:个体和互动高于流程和工具,可工作的软件高于详尽的文档,客户合作高于合同谈判,响应变化高于...

    jctvc-software manual

    5. 编码器参数(Encoder parameters):编码器参数的设置对于视频的质量和编码效率有直接影响。手册中涵盖了诸如编码单元的定义、编码结构参数、运动估计参数、模式决策参数、量化参数、熵编码参数、条带编码参数、...

    java语言编码规范.pdf

    因此,每个参与软件开发的人员都应该遵循一套统一的编码规范,这不仅能提升工作效率,还能确保项目的可持续发展。 #### 2. 文件名规范 ##### 2.1 文件后缀 Java程序使用的文件后缀如下: - `.java`:Java源文件 ...

    编码约定(code guide line)

    遵循这套编码规范不仅可以提高代码的质量,还能提升团队协作效率。通过一致的编码风格,可以使项目更加整洁有序,便于未来的维护和扩展。希望所有参与 OpenSSO 项目的工程师都能遵循这些指导原则。

Global site tag (gtag.js) - Google Analytics