中小项目敏捷实践之六(关于团队)

**开发方法是一个系统工程,需要所有项目活动的相互配合。**

本心得是基于近两年两个中小项目(一个2000 Manday, 一个1500 Manday)的实践总结,希望能与大家一起探讨和进步。

- 每个团队成员都是项目所有者,促进团队和项目共同成长
- 培养团队的自组织性《硝烟中的Scrum和XP》
- 专家建议团队大小在6-9人《硝烟中的Scrum和XP》
- 保持团队一定的稳定性以形成Group Flow。
- 三个Part Time的团队成员不如一个Full Time的团队成员
- 关于团队组织类型
> 组件型(×)优点:每个成员都对特定组件熟悉。缺点:组件间的整合会耗费很多时间。
> 功能型(√)优点:每个成员都是特定功能的专家,责任明确。缺点:每个成员都需要学习不同的技术组件。
- 关于救火团队
> 成立于Bug过多时
> 解散于Bug解决后
> 保护团队成员专心做事,免受干扰
- 测试团队应尽早入驻团队(项目总结)
- 测试团队应独立于开发团队《硝烟中的Scrum和XP》
- 测试团队应是敏捷团队的一部分

[color=blue][b]关于项目所有者和项目责任人[/b][/color]

这里,暂且不高谈阔论团队的定义,单从为什么会形成团队来说明。

当前的软件环境已经很少会发生那种个人英雄的事了,软件变得越来越大,周期越来越长,需要的知识越来越多,所以就需要将不同知识的人力组织在一起,同心协力完成那些大型的系统。

注意,是同心协力,而不是各怀鬼胎。

相信各位程序猿朋友已经看到太多创业失败的故事,在创业开始时,各个创始人能够竭尽所能、互帮有无、同心协力地去完成既定的目标,他们每个人都是项目的所有者,每个人都向着同一个方向发力。就向下面这张图一样。这也就是[color=darkred]Group Flow[/color]形成时个美丽场景。

[img]http://dl2.iteye.com/upload/attachment/0097/7031/9ad0b00c-fab7-3cd6-b8e5-a9c05faf3c9e.jpg[/img]

但在创业到达一定程度或一定时期后,项目的目标越来越分散,考虑的事情也越来越多,如利益、权力等等。项目成员就会变成下面这样,你说能不失败吗?

[img]http://dl2.iteye.com/upload/attachment/0097/7033/b01d85b3-8198-31a1-9a04-421480cc8b28.jpg[/img]

相信各位程序猿朋友的公司里应该或多或少地发现上面的情况。

那么,我们如何才能做到让团队同心协力、互帮有无地去完成项目呢?

作者程序猿觉得,下面是最重要的两点。

1、每位程序猿都是项目的主人。(主人翁意识)
2、每位程序猿都有明确的职责。(责任感)

[b]关于项目所有者[/b]

只有当每位程序猿都是项目的主人时,每位程序猿才会像初期的创业项目成员一样竭尽所能地确保项目的成功。那么,在公司环境下,怎样才能让程序猿朋友愿意翻身做主人呢?项目奖金?工作绩效?作者程序猿觉得这些都很重要,但不是最最重要的。各位程序猿朋友试想一下,各位的职业生涯中,什么时刻是最快乐的?升职?No!加薪?No!抱得美人归?这个还没机会尝试,暂且不论。以作者程序猿的经验来看,一定是项目成功的时刻!是荣誉来临的时候!这时候,各级老板对项目的赞美,就如同自己的儿子被人赞美一样,是一种骄傲!是一种自豪!

作为项目经理,这时候千万要敞开胸怀,并记住和大声说出来,这是大家的成功,而不只是项目经理或某些核心成员的成功,这是整个团队的成功!

如果更进一步来说,团队对项目成功的追求,一定也伴随着对美的追求。

每一个成功的项目都是美丽的。每一个好的设计都是美丽的。每一段好的代码都是美丽的。每一个好的流程都是美丽的。每一次良好的沟通都是美丽的。如果是以美为目标,还有什么困难不能克服,还有什么辛苦不能承受?这就是艺术!

[b]关于项目责任人[/b]

既然每个程序猿都是项目的主人,那么自然要承担相应的责任。并且是明确的责任。例如某一个特定的功能点一定有一个唯一的所有者和责任人。那么,当产生和这个功能点相关的问题时,团队就可以找到相应的程序猿,以寻求他的帮助。这样,扯皮的事就不会在团队里发生。

所以,在可能的情况下,应当尽量组织功能型的团队,而不是组件型的。因为组件型的团队需要更多的沟通和合作,也不容易为每一个功能点设置唯一的所有者和责任人,也就更容易产生扯皮的事,尽管有时候并不是程序猿主观愿意的。

[color=blue][b]关于团队效率[/b][/color]

毫无疑问,当程序猿专注于某一工作并免受打扰时,工作效率是最高的。既然如此,项目经理的一个重要职责就是“保护”团队成员免受打扰。所以尽量避免Part Time这种安排发生。对Part Time的程序猿来说,不但效率不能得到保证,责任感,归属者都是难以得到保证的。

而在一些万不得以的情况下,例如项目的Bug突然变多,或Support工作突然变多,以至于影响到了正常的开发,可以偿试建立“救火团队”,让这些救火队员在团队外建立起来个保护罩,以保护团队免受打扰。当“打扰”下降到了可接受的范围时,则可以解散救火团队了。

作者程序猿所定义的可接受范围是:功能所有者能应付那些Bug和Support工作,并且开发计划(Sprint)不受影响。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值