程序员修炼之道系列 | 使用曳光弹找到目标
预备、开火、瞄准……在黑夜中用机枪射击,使用曳光弹可以提升命中率。
视频地址:https://www.zentao.net/programmer/tracer-80375.html
什么是曳光弹
曳光弹指的是一种装有能发光的化学药剂的炮弹或枪弹,发射后在黑夜中能显示子弹的轨迹。曳光弹可以及时反馈子弹轨道,距离目标还有多远,轨道如何。
将曳光弹运用到软件开发当中就是曳光代码。简单来讲,曳光代码的关键就是反馈结果,可让程序员看到目前做出来的东西距离目标还差多少。
使用曳光弹找到目标
现在的很多产品架构都比较复杂,有大量的外部依赖,需要诸多工具。因而,使用曳光弹能通过试验各种事物并检查它们离目标有多远来让你追踪目标。
例如:这个系统有五个架构层,我们先找到可以让这个系统运行的代码路径,然后实现这部分代码,剩下部分等以后再实现。这就是曳光弹中一个基本的骨架部分,后续的开发都在此基础上进行。
使用曳光弹找到目标,我们可以理解为:MVP + 即时的反馈 + 快速迭代。
当我们做出MVP——最小化可行产品,将其推向市场后,根据市场反馈弄清楚用户需求,快速更迭产品,最终形成有成熟的产品。
比如做一个商城,只需一个简单的登录界面,让用户可以成功登录,且找到商品成功购买。哪怕目前的产品列表中就只有一个商品,但是系统可以真实调用。这就是曳光弹,开发人员只要后续在这个基础上完善就好。
曳光弹并非总能击中目标
曳光弹击中的不一定总是目标,曳光代码也是一样。在击不中目标的情况下,曳光代码也可以帮助我们在反馈中调整方向,最终接近目标。具体可以参考以下步骤调整:
- 弄清楚目前和目标的差距;
- 思考用什么方式可以更好的接近目标;
- 如何修改已经做好的东西。
面对调整,小块代码更迭速度快、成本低。我们可以根据收集到的产品反馈快速更迭形成一个新的更精准的版本重新投入市场。以此不断重复,最终触达目标。
曳光代码的优点
- 用户能及早看到能工作的东西,可以及时得到市场反馈,以便更好的改进;
- 开发者打通了应用程序的所有层面,构建了一个团队能在其中工作的结构,以此增加团队信心和生产力;
- 有了一个集成平台,便是有了一个环境,做完单元测试后把代码加进来做持续集成,调试和测试会更快更精准;
- 项目可随时对外演示。无论是项目赞助商或团队高层,什么时候想看项目演示都可以;
- 更易于了解项目进展,循序渐进的去解决每一个任务。
我们在做产品的时候,可以用采用曳光弹式开发。避免了从复杂繁重的文档和大而全的设计开始。要直击要害,先实现一个可供操作和评估的东西,观察用户反应。一旦命中,再对其进行修缮和完备,反复在系统的各个部分实施这样的动作,形成最终完善的产品。