精益软件(lean software),是一种可以减少复杂性并使成本最小化的软件开发方式,是一种注重目标适用性、简单性和目标实现时间的构建、交付和运行软件的方式。其主要目标是简单化,即尽量避免复杂的东西。
精益思想:
- 精益工厂的环境是干净,井井有条的。 工作环境不仅指一个公司的工作环境,还指一个程序员个体的编码环境。
- 最大程度的了解团队的信息。 “去掉工位挡板,走出办公室,面对面交流,达到人尽其才”
- 准时化,零库存。 “没有实现价值的代码”“过度设计或者分析瘫痪”
- 单件流通,任务细化,及时提交。“尽量避免同时做几个项目,多个项目并行开发”“出现问题一定要立即解决”
- 工作流程一定是可视化。 “用一些工具简单的记录团队成员每天的工作内容”“与团队多开一些简短的standing metting” “结对开发”“一对搭档最好不要连续合作超过3天”
“消除浪费”--- 七种形式的浪费
生产中的浪费 | 软件开发中的浪费 |
详细目录 | 部分完成的工作;例如:中间工作产品,经常性的文档和计划,没有整合到整合流程中的组分 |
额外的处理 | 额外的处理;例如,文书工作,状态报告 |
生产过剩 | 额外的特性;例如:消费者没有利用的功能,并不是在真正必须的,没有增加业务价值。 |
运输 | 任务转换;例如:同时进行很多项目的工作。 |
等待 | 等待;例如:等待工作结束,等待一个架构,等待完整的测试结果 |
移动 | 移动;例如:从一个开发工具移动到另一个 |
缺陷 | 缺陷;例如:需求,设计,或者代码相关的缺陷 |
Forrester的分析师John Rymer,列举出七个精益软件开发的原则。
- 第一是“使用具有目标适应性的工具和平台”;
- 第二是“使用精益和敏捷的开发过程”;
- 第三是“遵循为工具和应用实现可插式组件的原则”;
- 第四是“雇佣熟练的开发人员”;
- 第五是“利用开源”;
- 第六个是“优化部署”;
- 最后一个是“拥有核心应用,出租或外包开发环境”。
举例:
- EJB容器需要进行大量的配置,解决该问题的办法就是Spring。
- 基于WS-SOAP(Simple Object Access Protoco)的技术规范非常复杂,而REST(Representational State Transfer)则可以很好地解决这一问题。
- Java EE和.NET非常枯燥难懂,对此精益开发的解决方案是使用像Ruby、Perl和Python这类的动态语言。
- 开发人员还常常因为项目时间太长,以致迷失目标而头痛。对此解决方案则是使用敏捷开发方法,它能“更紧密地将开发人员与用户联系到一起,以实现目标”。
“精益软件虽然可以很好地管理复杂性,但是不能完全消除复杂性。它只是引领开发人员,而我们也需要证明它是一个可行的办法。”