团队的特点:
1.团队有一致的集体目标,团队要一起完成这个目标。一个团队的成员不一定要同时工作。
2.团队成员有各自的分工,互相依赖合作,共同完成任务。
软件团队的模式:
1.主治医师模式
首席程序员“主刀”(负责处理主要模块的设计和编码),其他成员“为主刀医师服务”(从各种角度支持他的工作)。
2.明星模式
主治医生模式运用到极致,可以蜕化为明星模式。
3.社区模式
社区很多志愿者参与,每个人参与自己感兴趣的项目,贡献力量,大部分人不拿报酬。
4.业余剧团模式
个人在团队中听从一个中央指挥的指导和安排。
5.秘密团队
软件团队进行一些秘密的软件项目。
6.特工团队
软件行业的一些团队由一些有特殊技能的专业人士组成,负责解决一些棘手而紧迫性的问题。
7.交响乐团模式
家伙多,门类齐全;各司其职,各自有专门场地,演奏期间没有聊天、走动等现象;演奏都靠谱,同时看指挥的;演奏的都是练习过多次的曲目,重在执行。
8.爵士乐模式
不靠谱;没有现场指挥;人数较少。
9.功能团队模式
具备不同能力的同事们平等协作,共同完成一个功能。
10.官僚模式
几个人报告给一个小头目,几个小头目报告给中头目,依次而上。
开发流程
写了再改模式适用于以下任务:
1.只用一次的程序
2.看过了就扔的原型
3.一些不实用的演示程序
瀑布模型适用于以下情况:
1.如果产品的定义非常稳定,但是产品的正确性非常重要,需要每一步的验证
2.产品模块之间的接口、输入和输出能很好地用形式化的方法定义和验证
3.使用的技术非常成熟,团队成员都很熟悉这些技术
4.负责各个步骤的子团队分属不同的机构,或在不同的地理位置,不可能做到频繁的交流
第6章主要是讲敏捷流程,敏捷流程是一系列价值观和方法论的集合。
敏捷流程相较于传统的软件模型来说,更加注重个人和交流,软件的可用性,与客户的合作和响应变化。
敏捷开发的原则:1.时间尽早;2.响应变化;3.持续更新;4.共同合作;5.有上进心;6.面对面交流;7.有指标;8.可持续;9.关注更新;10.简化;11.自我管理;12.提高效率。
敏捷流程概述:
1.找出完成产品需要做的事情--Product Backlog。
2.决定当前的冲刺(Sprint)需要解决的事情--Sprint Backlog。
3.冲刺(Sprint)。
4.得到软件的一个增量版本、发布给用户。然后在此基础上又进一步计划增量的新功能和改进。
敏捷对团队有三个要求:自主管理、自我组织、多功能型。
敏捷流程的经验教训
1.敏捷宣言表明的是一些优先级,不必当作圣旨或者教条来争论。
2.Scrum Master不是一个官,而是一个没有行政权力的沟通者,就像微软的PM那样。他/她同时还要在团队中做具体的工作。直接把原来的“经理”变成Scrum Master,大多行不通。
3.一些项目需要很多暗箱操作和政治角力才能搞定,Scrum会把这些矛盾都摆到明处。这有好处,也有风险。
4.在复杂的项目里,让一线团队成员做决定。
5.创业公司的团队其实经常是运行在Scrum的模式中(只不过大家太忙,没工夫论证自己到底有多么Scrum)
6.在Scrum计划阶段的估计不是一个“合同”,领导们不要把它当成一个合同。估计总是不准的。坚持短期的Sprint,这样即使不准的估计也不会有大的损害。
7.不要和管理层谈“流程”,他们只关心“结果”。
8.在大型团队、跨地区的团队,或者复杂项目中,Scrum并没有非常完美的答案,Scrum的创始人也承认这一点。