第3部分 软件研发工作总结

软件需求

 

        软件project师的工作职责是什么?一句话,就是完毕软件需求。大家每天都接触到的软件,都是从软件需求一步步进化而来的。那么,软件需求是什么?怎样完毕需求?在完毕需求的过程中我们要注意哪些问题呢?本文将为你解答这些问题。

1. 什么是软件需求?

        通俗地讲,软件需求是指要求软件开发project师完毕的软件的功能。

比如。假设要求一个软件具备文件处理的能力,要求一个WEB页面具备显示客户信息的能力。要求一款手机具备指纹识别的能力,等等,这些要求都是软件需求。

        用较为专业一点的术语来说。需求指被描写叙述对象(也就是软件)“做什么”(功能需求)及“做什么”时的水平(非功能需求。如性能需求、质量属性需求、外部环境需求等)。

 

        需求与开发的关系如图1所看到的:

让你提前认识软件开发(50):软件需求_数据库

图1 需求与开发的关系

 

2. 软件需求演示样例

        假设要求做一个软件来实现文件处理功能,则一个较为完整的软件需求例如以下所看到的:

需求背景:客户要求软件具备文件处理能力,以获取文件里的信息。

需求描写叙述:该软件处理本地文件里的信息。并将读取到的信息保存到数据库中。

运行者:本软件

优先级:高

使用频度:软件运行时运行

前置条件:数据库和操作系统正常运行

后置条件:无。

正常过程:

Step 1:该软件周期性地扫描本地指定的文件文件夹,以发现按要求命名的文件;

Step 2:扫描到文件之后,程序对读取到的内容进行解析,并将解析后的内容写入到指定的数据库中。

可选过程:无。

 

异常过程:假设本地文件夹里面没有文件。则程序继续运行而不停止。

特殊需求:不处理pdf格式的文件。

需求来源:运营商客户。

 

        一条软件需求包含了以上诸多的内容,其目的就是把须要做的东西描写叙述清楚,以便于开发者编敲代码实现该需求。

 

3. 完毕需求过程中的角色分工

        在一条需求从产生到完毕的过程中。牵涉到的主要人员包含下面几类:

        (1) 系统project师(System Engineer,简称SE):他们负责写需求。并在开发过程中不断完好需求,同一时候解答研发人员的疑问。

        (2) 开发project师(Development Engineer):他们负责用程序代码实现需求。并就需求中的问题与SE沟通。

        (3) 測试project师(Test Engineer):他们主要对开发project师做出的软件进行測试,并就相关问题与开发project师和SE沟通。

 

        以上三类角色的互动情况如图2所看到的:

让你提前认识软件开发(50):软件需求_功能需求_02

图2 三类角色的互动情况

 

4. 开发project师怎样准确地完毕需求?

        (1) 參加需求评审会议。了解需求所要实现的功能。并就需求的合理性进行评估,剔除不合理的、有歧义的、实现难度非常大的需求。

 

        (2) 在開始编码之前,做好软件的具体设计并发起评审。确保软件流程的正确性及功能的完整性,降低后期改动所带来的麻烦。

 

        (3) 在编码的过程中。细致阅读需求,确保对之有了准确的、透彻的的理解。

假设在需求实现过程中发现了需求问题或有所疑惑的地方,及时与SE沟通(最好面对面沟通)。

        (4) 在完毕了一个功能之后,即对代码进行自測(单元測试)。确保已实现功能的正确性。

在全部功能都实现之后,还要对整个程序进行測试(集成測试)。

 

        (5) 在提交程序之前。确保代码、文档都已齐备,最后再对程序版本号的完整性进行检查。

 

        一切软件都是从需求開始的。因此。对于软件需求。开发者一定要抱着高度负责任的态度,高速、准确地将事实上现。以做出高质量的软件产品。