《实例化需求:团队如何交付正确的软件》阅读笔记3

2011年12月份上海的AgileTour大会上,Gojko Adzic 发表了一个题为 Take the business along for a ride 的演讲。演讲中的一个故事我至今印象深刻,故事的主角是F-16战斗机,它的最初的设计需求是飞行速度要达到2-2.5马赫,首席设计师 Hillaker 询问美国空军为何需要如此快的飞行速度,答复是“飞机必须能从战斗中逃脱”,然而,意外的是,Hillaker 的最终设计并没有达到2马赫,但通过无框气泡式坐舱盖、倾斜的座位、侧装式控制杆等等诸多创新技术,飞行员可以非常敏捷地从战斗中逃脱,并且这样的设计生 产成本更低!看似明晰的“2.5马赫”并未有效地传达真正的需求,那只是一种解决方法,Hillaker 通过理解真正的需求而给出了更好的设计,这是成功产品设计的本质!

[+]查看原图

Gojko Adzic 是《实例化需求》的作者,该书在 Amazon.com 获得了超过了20条的几乎全五星的评价,而在今年的9月,本书又获得了软件开发图书领域最富盛名的 Jolt 大奖!这一奖项意味着《实例化需求》基本是上从2011年6月到2012年7月这一年中对软件行业影响最为重大的一本书。

这到底是一本什么样的书?它与我在本文看透提到的故事又有怎样的联系?在第一章 Gojko Adzic 就清晰地说到:

在过去的十年里,软件开发社区致力于使用“正确”的方式构建软件,关注使用技术实践和思想来确保质量。但是,正确地构建软件构建正确的产品是两码事,我们要二者兼顾才能取得成功。

这是一本讲述如何构建正确产品的书。

我们的行业太需要这样一本书了!往身旁看看,程序员醉心于技术而不太关心为什么要开发手头的产品特性;客户说不清楚自己到底想要什么;业务分析师筋 疲力竭地试图理解客户真正的需求并传达给程序员;测试人员一遍又一遍地运行着手工测试。大家辛辛苦苦忙活好半年,出来的产品特性中有百分之多少有真正的业 务价值的?又多少产品特性其实是无法给项目干系人带来收益的?再看一看当今流行的敏捷方法论,例如极限编程和 Scrum ,在如何构建正确的产品方 面它们其实并没有太具体的论述。Scrum 是抽象的框架,定义的内容非常少,在如何与客户协作方面它只定义了几个角色的一些必要的会议;极限编程中有一条实践叫客户测试(也叫验收测试),但也定义 得很简单,具体怎么做?会遇到怎样的困难?需要多大的成本?这些都是大家更为关心的内容。

怎样的产品才是正确的产品?客户知道吗?也许知道一点;产品分析师知道吗?也许知道更多一点;测试人员的知识挺重要;程序员当然也少不了,但无法完 全依赖于他们。看来只有提炼各种角色人员的知识才能得到正确的产品,因此协作是必须的。当然大家都知道要协作,可说起来容易做起来难,怎样的协作方式效率 更高?Gojko Adzic 说要借助实例的力量!他还进一步总结了一套非常清晰的关键过程模式

实例的作用真的那么强大?这一关键过程模式是否有效?我基于本书的结构组织了一个主题为ATDD1 的workshop,邀请到了很多产品负责人、测试人员、程序员以及项目经理的参与。我把大家分成几个组,各组都包含不同的角色,简单介绍了实例化需求的 基本概念和目的之后,我挑选了书中的一个简单例子,给出商业目标和范围,让各个小组协作制定需求说明、举例说明、进一步提炼并使用Gherkin语言2 描述。一个半小时之后,最终的结果超出了大家的预期,所有组都认为对于需求大家达成了清晰的共识,很多人总结时都说体验到了实例的强大,编写代码自动化验证这些实例看起来也不是什么难事,还有一些人则饶有兴致地讨论起用哪一种工具实施自动化更有趣。

有了这样的经验,我就更有信心给所有软件开发从业人员推荐《实例化需求》了。不过对于项目经验缺乏或者是喜欢看代码的人来说本书可能会显得艰涩,在前言里作者就说了:

本书没有源代码,也不介绍任何工具。

因此想了解工具的人需要找其他书籍补充,但缺乏项目经验会比较麻烦,因为书中有大量的案例分析和访谈、涉及了各种各样的角色和场景,这些内容对于有经验的软件从业人员极具参考价值,但也会让新手摸不着头脑。

根据我的经验,很多人,尤其是程序员,在刚接触实例化需求或ATDD的时候,会过多的关注工具而忽于协作。事实上开发人员和用户之间良好的协作远比 选择使用Cucumber还是Fitness来得重要,不要忘了,我们更应该关心是如何让F-16战斗机能够更容易从战斗中逃脱,而不是花上很大的代价非 要让它的飞行速度达到2.5马赫。

1. 你可以大致把ATDD理解成实例化需求的另一个名字,反之亦然。
2. Gherkin语言是实例化需求工具Cucumber的一部分,通过及其简单的Given/When/Then语法及表格帮助描述业务人员能轻易理解的需求说明。

转载于:https://www.cnblogs.com/bdqczhl/p/5004351.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据来源:中经数据库 主要指标110多个(全部都是纯粹的 市辖区 指标),大致是: GDP GDP增速 第一产业增加值占GDP比重 第二产业增加值占GDP比重 第三产业增加值占GDP比重 人均GDP 社会消费品零售总额 固定资产投资(不含农户) 新设外商投资企业数_外商直接投资 实际利用外资金额(美元) 一般公共预算收入 一般公共预算支出 一般公共预算支出_教育 一般公共预算支出_科学技术 金融机构人民币各项存款余额_个人储蓄存款 金融机构人民币各项存款余额 金融机构人民币各项贷款余额 规模以上工业企业单位数 规模以上工业企业单位数_内资企业 规模以上工业企业单位数_港澳台商投资企业 规模以上工业企业单位数_外商投资企业 规模以上工业总产值 规模以上工业总产值_内资企业 规模以上工业总产值_港澳台商投资企业 规模以上工业总产值_外商投资企业 规模以上工业企业流动资产合计 规模以上工业企业固定资产合计 规模以上工业企业利润总额 规模以上工业企业应交增值税 规模以上工业企业主营业务税金及附加 户籍人口数 年均户籍人口数 户籍人口自然增长率 第一产业就业人员占全部城镇单位就业人员比重 第二产业就业人员占全部城镇单位就业人员比重 第三产业就业人员占全部城镇单位就业人员比重 城镇非私营单位就业人员数 城镇非私营单位就业人员数_第一产业 城镇非私营单位就业人员数_第二产业 城镇非私营单位就业人员数_第三产业 城镇非私营单位就业人员数_农、林、牧、渔业 城镇非私营单位就业人员数_采矿业 城镇非私营单位就业人员数_制造业 城镇非私营单位就业人员数_电力、热力、燃气及水生产和供应业 城镇非私营单位就业人员数_建筑业 城镇非私营单位就业人员数_批发和零售业 城镇非私营单位就业人员数_交通运输、仓储和邮政业 城镇非私营单位就业人员数_住宿和餐饮业 城镇非私营单位就业人员数_信息传输、软件和信息技术服务业 城镇非私营单位就业人员数_金融业 城镇非私营单位就业人员数_房地产业 城镇非私营单位就业人员数_租赁和商务服务业 城镇非私营单位就业人员数_科学研究和技术服务业 城镇非私营单位就业人员数_水利、环境和公共设施管理业 城镇非私营单位就业人员数_居民服务、修理和其他服务业 城镇非私营单位就业人员数_教育 城镇非私营单位就业人员数_卫生和社会工作 城镇非私营单位就业人员数_文化、体育和娱乐业 城镇非私营单位就业人员数_公共管理、社会保障和社会组织 城镇非私营单位在岗职工平均人数 城镇就业人员数_私营企业和个体 城镇非私营单位在岗职工工资总额 城镇非私营单位在岗职工平均工资 城镇登记失业人员数 建成区面积 建设用地面积 建设用地面积_居住用地 液化石油气供气总量 液化石油气供气总量_居民家庭 人工煤气、天然气供气总量 人工煤气、天然气供气总量_居民家庭 液化石油气用气人口 人工煤气、天然气用气人口 城市公共汽电车运营车辆数 城市出租汽车运营车辆数 城市公共汽电车客运总量 道路面积 排水管道长度 建成区绿化覆盖面积 建成区绿化覆盖率 绿地面积 公园绿地面积 维护建设资金支出 土地面积 生活用水供水量 供水总量 全社会用电量 城乡居民生活用电量 工业生产用电量 房地产开发投资 房地产开发投资_住宅 限额以上批发和零售业法人单位数 限额以上批发和零售业商品销售总额 普通中学学校数 中等职业教育学校数 普通小学学校数 普通高等学校专任教师数 普通中学专任教师数 中等职业教育专任教师数 普通小学专任教师数 普通高等学校在校生数 普通中学在校生数 中等职业教育在校生数 普通小学在校生数 电视节目综合人口覆盖率 公共图书馆总藏量_图书 医疗卫生机构数_医院和卫生院 卫生人员数_执业(助理)医师 医疗卫生机构床位数_医院和卫生院 城镇职工基本养老保险参保人数 职工基本医疗保险参保人数 失业保险参保人数

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值