瀑布式开发
正规军开发一个商业软件,一般分为这些步骤:
- 需求分析
需求分析阶段的任务是确定用的需求。找用户聊天,了解痛点,和操作步骤,确定需要什么样的软件功能帮他们解决问题。
需求分析阶段的产出是软件需求说明书。
- 软件设计
软件设计基于软件需求转换成一系列的类,接口,方法。类和类之间的关系图等。
软件设计一般由资深程序员或者架构师完成。软件设计的产物一般是概要设计说明书(TAD)和软件详细设计说明书。
- 软件开发
软件开发人员基于软件设计吭哧吭哧的写代码,变成可用的软件。
- 软件测试
软件测试根据需求验证开发出的软件是否符合各项功能需求。
- 用户验收
最后拿给用户,看看用户是否满意。
一个更完整的过程类似这样:
image.png
教科书里的世界 vs 现实世界
上面是教科书里教的,也是软件产业的前几十年一直在用的方法。
一个软件从需求分析到最后拿给用户看,严格一步步来,可能需要经过几个月甚至一两年的时间。
最后的结果可能类似下面这幅漫画:
image.png在现实世界中,你会发现:
-
不管前面需求分析的多么详细,在设计和开发中总会发现还是需要再去调整需求。如果碰到一个脑洞大开的客户,那就更麻烦了,三天两天的变化需求。
-
不管设计的多么详细,在开发过程中总会发现设计考虑的不够全面,设置有些小的矛盾,需要再去调整设计。
所以瀑布模型有很大的问题,我们应该用下面这种开发模式。
迭代式开发
迭代式开发是指先选取一两个核心功能,快速的走上面的步骤:分析,设计,开发,测试,给用户看。然后根据用户的反馈再完善功能,逐渐添加功能。
迭代式开发大致是这样的:
image.png
网友评论