如何从复盘中获得真正的收获?持续改进是关键!

news2024/11/24 12:41:57

复盘,本是围棋术语,每次博弈结束后,双方棋手把刚才的对局复演一遍,分析对局当中得失关键,提升自己棋力的好方法。复盘是对思维的训练。 通过复盘,当类似局面再次出现,你就能快速预测接下来的动态走向,更好应对。

项目复盘会则是 项目团队有意识从过去行为经验中,进行集体学习的过程。 一般在项目或里程碑完结后,由项目经理组织召集项目成员,一起回顾项目整个历程中,团队做对哪些事,做错哪些事,再来一次,如何做更好,沉淀该项目产生的集体智慧。

多做复盘肯定有好处,可现实项目是一个接一个做,忙上线,忙变更,忙返工,哪有时间复盘?我之前有个老板,倒是经常拉大家复盘,但会上就是骂,出问题就追责到底,自然各种甩锅。我也想开好复盘,可是,怎么才能让复盘不流于形式,真正做到集体学习?

如何做好项目复盘,如何通过复盘去培养团队的持续改进能力?

1 复盘会的基调设定

复盘会前,想清楚复盘的目的,设定好复盘基调,更重要

曾组织过复盘“坑爹功能”大搜罗。参与复盘十多TL,在现场写20多页纸,满满当当罗列曾经做的、却没人用的功能。实际上,只有当大家真正摊开不太愿意面对的真相,去认真思考背后的深层原因时,我们才能共同进入真正的集体反思区。这样坦诚地直面问题的复盘,才能促发有意识的集体学习。

想让参与者真正进入集体反思区,会前就要设定好开放的复盘基调。每个人都可以在自己所处的环境中,看到各种问题。若复盘是追责,那会议刚开始时,大家就能迅速感受到。这样每个人都会小心避开自己的问题,转而说别人的问题,复盘失去意义。

如何设定开放的基调

自己要先进入反思区。

在那次复盘会之前,我跟这个部门的负责人,就部门中反复出现的各种问题,进行过多次深度沟通。一开始,这位负责人觉得团队到处是问题。但当我们把问题层层剖析开来看,发现很多问题背后深层原因。

在会议刚开场,要展示出自己的开放与坦诚,给复盘会奠定基调:这次复盘不是来挑问题的,而是为了找到问题的根源并改进的。

那次复盘会,这负责人特意讲了自己这一年深刻反思,带动了大家敞开心扉直面问题。大家自发地找到了在各个环节有效避免无用功能的方法。会议结束后,部门还发起“整风运动”,从增强用户意识的讲座,到用户调研方法的培训,再到激励与考核制度的挂钩,让复盘会反思的成果,逐渐渗透到每个人的日常工作。

2 复盘会的会前准备

还需要充分的会前准备。

复盘会前,要梳理整个版本的历程,包括项目或里程碑的各项数据和信息、目标和达成结果、进度计划、需求变更、质量状况等,都是客观数据总结。还可提前收集这版本期间,团队满意度的问卷调查,为复盘会引入更多主观输入。

视频也是好的回顾材料。某次重要版本复盘会前,我熬夜加班,为团队准备段回顾视频。因为团队刚完成一件几乎不可能完成任务。客户需求急切,往常要做一个半月大版本,直接压缩到3w,团队辛苦。虽然视频制作手法粗糙,但那些加班到深夜开迭代演示会的照片,还是让现场很多人感动,瞬间为疲惫团队注入能量。

复盘会的基调设定及会前准备工作,在开会前,就很大程度决定复盘会的效果。

3 复盘会的简易流程

最高效的复盘流程:

  • 现场回顾总结项目/里程碑的整体概况,包括目标达成情况、进度计划及变更情况、需求变更情况、质量报告等项目历程记录
  • 与会人员便签纸写下项目过程中做好、做不好的3点,按项目各环节分类,分别贴在白板,确保大家意见充分、自由表达
  • 在白板前逐条review大家意见,共同发现问题,并针对性展开讨论
  • 对大家总结出的好、不好点,进行集体投票
  • 由项目经理整理投票结果,对做得好的环节,总结经验;做得不好的环节,当场讨论出改进方案

我们来看看一次真实的项目复盘会的投票结果:

做得好:

  • (10票) Bug Bash 活动成功开展,对产品质量控制有很大帮助,提升了团队合作意识及产品Ownership。
  • (7票)专职的 项目经理 角色让项目各项进度控制更加有序。
  • (6票) WBS 工作分解进一步明确范围及职责,为Schedule进度控制提供更加准确的基准依据。

有待改进:

  • (7票)后台开发与各端的沟通不畅,接口变更频繁,异地沟通成本高
  • (3票)缺少对开发质量的控制机制:缺少适当的Code Review;单元测试做得很不够
  • (2票)自动测试缺失:自动测试覆盖率不够

这项目是第一次引入项目经理。这次复盘会,项目经理的工作得到一致认可,包括Bug Bash引入、WBS工作分解、进度控制等措施,帮助团队快速从混乱到有序。再看待改进项,投票最多一项:后台研发与各端沟通瓶颈,这就是你在下版本一定要解决。

分析

发现是由于工期紧张,在后端接口没成熟时,前端、客户端须同时开发,如此快节奏迭代,后台接口频繁变动,牵一发动全身,让后端成项目瓶颈。为改善问题,成立专门Triage小组(判别小组),由各端主程组成,每天固定15min,参与者线上同时连线,对每端提出的接口变动需求,进行统一判断,并决策,确保接口变更信息第一时间同步。

无法促发行动的复盘,说再好都空谈!一开始开复盘会,大家会期待解决的问题越多越好,但焦点增多后,哪个都是蜻蜓点水,哪个都没改彻底。下次再开会,发现之前反馈问题依然在,谁还有动力继续提问?

改进措施要落地,重点行动别太多,一个就够! 若每次复盘聚焦改进项的Top 1,确保改进措施真正落地,长期坚持下去就会形成持续能力提升。

复盘次数不宜多,你不需每个版本、每个迭代都例行公事做一遍,确保每个季度有一到两次里程碑复盘,可完整地对项目做系统化的梳理,达到落地效果更重要

4 打造团队持续改进能力

其实,项目复盘不只是一次会议,它更应该成为团队持续改进的推动力。那么,怎样才能让一次成功的复盘发展成为复盘文化,激发团队自主地持续精进呢?

实际上,想要让团队进入自发改进的正向循环,你需要更好地激发团队的主人翁意识,让团队成为复盘的主角,而不是你。最重要的是,你不仅要关注事,还要关注人

我曾经为某部门组织过一次复盘会,取名叫作“研发代表大会”。当时,我们把部门中所有资深的程序员召集在一起,让他们给平台越来越严重的技术债问题出谋划策。这次复盘我采用了“批奏章”的玩法,各位代表把自己的意见写在纸上,然后围成一个圈,依次传递给左边的同学,每个人把手上的“奏章”批阅完成后,继续往左传。这样一圈转下来,+1数最多的那份“奏章”,就会被选出成为年度力荐。

最后,这份“奏章”得到了最多的关注和资源,这项建议迅速得到了改善。同时,这样的复盘方式,也让更多的研发同学享受到了“批奏章”的愉悦感,一旦他们发现,自己选出的“奏章”会得到采纳和落地,那么这个“研发代表大会”也就可以真正自行运转起来,更多人愿意主动参与进来,通过这个平台,发表自己的见解,为整体的持续改进贡献一份力量。

越困难时期,越是塑造团队能力大好机会。团队遇到重大困难时,你也能及时组织复盘会,深度关注调整个人状态。我曾试过让每个人画出自己进入项目组后的状态变化曲线,跟大家分享高光时刻、至暗时刻。业务低落期,这样的复盘会会成为重要转折点,让团队力量得到深度聚合。

这些对人的关注,都会让复盘会超越问题解决层面,推进事的同时,促使团队自发地推进问题的解决,并把经验内化下来,从而不断提升团队的持续精进能力。

5 复盘方法

帮助提升团队在复盘会中的参与感,进而达到有效复盘的目的:

  • 3点法:使用最多、最常见
  • 奏章法:“坑爹功能大搜罗”“研发代表大会”都这法,用来集结群智,每人发一张白纸,写上几条意见,然后依次传给左边的同学批阅,同意就+1,也可以在上面盖楼写评论
  • 状态图法:当团队士气遇到挫折时,凝聚士气的一个方法。每人发一张白纸,在上面画出自己进项目组以来的心情曲线,轮流公开呈现,并讲出自己的波峰和波谷事件及感受。具体操作起来,让Leader先讲,创造坦诚氛围,大家自然就踊跃

复盘方法可多样,便签、白纸等都是匿名方式,帮助大家卸下包袱。其实,不管你怎么玩,能让大家能够畅所欲言,才是关键。

听到这里,艾文恍然大悟,“这下我明白了,团队的参与感最重要。不过,如果团队自己通过复盘,找不到问题的要害或者解决方案,那又怎么办呢?”

复盘会是集体智慧的总结,产出肯定跟参与的群体直接相关,这里的解法,一个是引入可以直接提供有效意见的人员参与进来。另外,有些情况下,你需要有不同层面的复盘会,去解决不同层面的问题,比如执行团队复盘之后,反馈出整体规划层面的重要问题,那就应该召开负责人层面的复盘会,或推动更高层面讨论解决。

6 总结

当人们在说复盘时,往往会把焦点放在复盘会本身。但我认为决定复盘成功与否的关键,不在会议本身,而在于复盘会的一前、一后两环:

  • 复盘会前,复盘基调的设定是否开放,复盘会前的各项准备是否充分,对于复盘会的效果非常关键。组织一个复盘会本身并不难
  • 难的是在复盘会后,持续跟进这些反思,落地为切实的改进措施,让团队真正看到效果,从而打开团队持续改进的正向循环

做好一次复盘,每次复盘后聚焦一个改进点。聚焦点别太多,一个就够!

FAQ

你经历过的印象最深刻的一次复盘,打动你的是什么?回顾一下你经历过的那些项目,若可再来一次,你最想要做好的是啥?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/609150.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【网络】TCP套接字创建服务客户端与守护进程

文章目录 Tcp服务端TcpServer.hppTcpServer.cc Tcp客户端TcpClient.hppTcpClient.cc TCP客户端处理守护进程守护进程化 Tcp服务端 TcpServer.hpp TCP服务端创建流程如下: 创建socket文件套接字对象,面向字节流SOCK_STREAM bind绑定自己的网络信息&…

nacos注册中心配置springboot动态刷新源码解读

0丶简介 如何快速启动,请去官网看文档,言简意赅 https://nacos.io/zh-cn/docs/quick-start.html 只描述为何实现动态刷新的关键源码 1丶基于目前最新版本 <!-- https://mvnrepository.com/artifact/com.alibaba.boot/nacos-config-spring-boot-starter --> <depend…

命名管道详解

一、命名管道 1、命名管道与匿名管道一个很显著的区别是&#xff1a;匿名管道只能在有血缘关系的进程间进行通信&#xff0c;但命名管道可以让两个毫无关系的进程进行通信。 2、如果我们想在不相关的进程间交换数据&#xff0c;我们可以用到FIFO文件来进行通信&#xff0c;这…

【Nginx rewrite】

目录 一、常见的Nginx 正则表达式二、location1、location 解释2、location 示例说明&#xff1a;3、实际网站使用中&#xff0c;至少有三个匹配规则定义&#xff1a; 二、rewrite1、rewrite跳转实现&#xff1a;2、rewrite 执行顺序如下&#xff1a;3、rewrite 示例 一、常见的…

B-3:Linux 系统渗透提权

B-3&#xff1a;Linux 系统渗透提权 任务环境说明&#xff1a; 服务器场景&#xff1a;Server2204&#xff08;关闭链接&#xff09; 用户名&#xff1a;hacker 密码&#xff1a;123456 1.使用渗透机对服务器信息收集&#xff0c;并将服务器中 SSH 服务端口号作为 flag 提 …

Java工厂模式(随笔)

前言&#xff1a;Java工厂模式是一种创建型设计模式&#xff0c;它提供了一种将对象创建过程封装到一个单独的类中的方式&#xff0c;这个类就是被称为‘工厂类’&#xff0c;它根据特定的条件来决定应该创建哪个对象&#xff01; 文章目录&#xff1a; 三大工厂模式介绍特殊工…

计算机网络第二章——物理层(上)

提示&#xff1a;男儿何不带吴钩&#xff0c;收取关山五十州 文章目录 2.1.1 物理层基本概念知识引导物理层接口特征 2.1.2 数据通信基础知识数据通信相关术语数据通信系统要考虑的问题三种通信方式串行传输&并行传输同步传输&异步传输 脑图时刻 2.1.3 数据通信基础知识…

Google Play上架aab保姆级教程(纯aab上架/已上架apk转aab上架)

0、上传密钥 & 应用签名密钥 “Google 会使用上传证书验证您的身份&#xff0c;并使用您的应用签名密钥为 APK 签名以进行分发” 以上为官方解释。 2021年8月起&#xff0c;上传google play的应用必须以aab格式&#xff0c;aab的签名流程要比之前apk的复杂一些。需要上传…

如何真正有效地应对项目中的需求变更?

需求变更在奉行唯快不破的互联网公司&#xff0c;可算程序员头号噩梦&#xff0c;“996”直接元凶。 阿里口号拥抱变化。既然需求变更无法被消灭&#xff0c;就要通过学习&#xff0c;掌握更好应对需求变更方法。 1 常见的需求变更流程 先要发起变更申请&#xff0c;由变更委…

从IO多路复用到redis线程模型

文章目录 Unix IO模型分类阻塞IO - Blocking IO非阻塞IO - NoneBlocking IOIO多路复用 - IO multiplexing信号驱动IO - signal driven IO异步IO - asynchronous IO同步与异步的定义阻塞与非阻塞的定义 IO多路复用有哪些实现IO多路复用的大致实现selectpollepoll redis的线程模型…

Python实战基础19-异常处理及程序调试

1、异常概述 在程序运行过程中&#xff0c;经常会遇到各种各样的错误&#xff0c;这些错误统称为“异常”。 这些异常有的是由于开发者将关键字敲错&#xff0c;这类错误产生的是SyntaxError:invalid syntax&#xff08;无效语法&#xff09;&#xff0c;这将直接导致程序不能…

3.二进制高可用安装k8s 1.23集群(生产级)

二进制高可用安装k8s集群(生产级) 本文档适用于kubernetes1.23 节点 Etcd Cluster Etcd是一个数据库,k8s做的一些变更啥的都会存到Etcd中 如果集群比较大建议与master节点分装,单独装Etcd master节点 master分为几个重要的组件 你所有的流量都会经过Kube-APIServer Co…

排序算法——希尔排序图文详解

文章目录 希尔排序基本思想整体插入思想预排序结论 代码实现实现代码直接插入排序与希尔排序的效率比较测试代码&#xff1a; 时间复杂度 希尔排序 注1&#xff1a;本篇是基于对直接插入排序法的拓展&#xff0c;如果对直接插入法不了解&#xff0c;建议先看看直接插入排序 注…

Learning C++ No.27 【布隆过滤器实战】

引言 北京时间&#xff1a;2023/5/31/22:02&#xff0c;昨天的计算机导论考试&#xff0c;三个字&#xff0c;哈哈哈&#xff0c;摆烂&#xff0c;大致题目都是一些基础知识&#xff0c;但是这些基础知识都是非常非常理论的知识&#xff0c;理论的我一点不会&#xff0c;像什么…

【自制C++深度学习框架】表达式层的设计思路

表达式层的设计思路 在深度学习框架中&#xff0c;Expression Layer&#xff08;表达式层&#xff09;是指一个通用的算子&#xff0c;其允许深度学习网络的不同层之间结合和嵌套&#xff0c;从而支持一些更复杂的操作&#xff0c;如分支之间的加减乘除&#xff08;elementAdd…

PyTorch 深度学习 || 专题二:PyTorch 实验框架的搭建

PyTorch 实验框架的搭建 1. PyTorch简介 PyTorch是由Meta AI(Facebook)人工智能研究小组开发的一种基于Lua编写的Torch库的Python实现的深度学习库&#xff0c;目前被广泛应用于学术界和工业界&#xff0c;PyTorch在API的设计上更加简洁、优雅和易懂。 1.1 PyTorch的发展 “…

Numpy---生成数组的方法、从现有数组中生成、生成固定范围的数组

1. 生成数组的方法 np.ones(shape, dtypeNone, orderC) 创建一个所有元素都为1的多维数组 参数说明: shape : 形状&#xff1b; dtypeNone: 元素类型&#xff1b; order &#xff1a; {‘C’&#xff0c;‘F’}&#xff0c;可选&#xff0c;默认值&#xff1a;C 是否在内…

BPMN2.0自动启动模拟流程

思路&#xff1a;BPMN的流程模拟启动&#xff0c;主要是通过生成令牌&#xff0c;并启动令牌模拟 流程模拟的开启需要关键性工具&#xff1a;bpmn-js-token-simulation&#xff0c;需要先行下载 注&#xff1a;BPMN2.0的流程模拟工具版本不同&#xff0c;启动方式也不一样&am…

Kafka某Topic的部分partition无法消费问题

今天同事反馈有个topic出现积压。于是上kfk管理平台查看该topic对应的group。发现6个分区中有2个不消费&#xff0c;另外4个消费也较慢&#xff0c;总体lag在增长。查看服务器日志&#xff0c;日志中有rebalance 12 retry 。。。Exception&#xff0c;之后改消费线程停止。 查…

chatgpt赋能python:Python实现数据匹配的方法

Python实现数据匹配的方法 在数据分析和处理中&#xff0c;经常需要将两组数据进行匹配。Python作为一门强大的编程语言&#xff0c;在数据匹配方面也有着其独特的优势。下面我们将介绍Python实现数据匹配的方法。 数据匹配 数据匹配通常指的是将两组数据根据某些特定的规则…