如何处理软件非功能需求
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
如何处理软件非功能需求
当你收集需求时,你可以从用户的需求清单中找出他们想要软件完成什么样的任务,有相关的用例、故事板、需求说明出书来捕捉这样的信息,那么什么又是非功能性需求,又有什么样的内容定义呢?
不合理或无法说清的非功能性需求如:
·系统一定要快
·系统必须要安全
·系统要有尽量高的灵活性
·系统要有较高的可用性
· ....
非功能需求的大体分类:
·性能需求:
响应时间:从发出请求到收到反馈的时间,比如点击超链接或桌面应用中的按钮。
延时时间:消息从从A到B,经过你的系统所有的时间。
·可用性需求
使用正常运行时间的百分比描述可用性如:99.9%,99.99%等。
使用可容忍的停机时间百分比来描述可用性如:0.1%,0.01%等。(当容忍停机时间为0.1%时,平均每天留给用户维护、升级与处理故障的时间为1.44分钟)
·可伸缩性
可伸缩性与并发性密不可分,就是处理更多用户、请求、数据、消息的能力,可以以“相同时间内处理多少东西”来描述(如每秒请求数)。
·灵活性
系统可以使用不同的方式来执行单个任务,需求描述用例如:用户可以通过配置文件等方式来改变内部业务规则的能力。
·安全性
安全性包括了认证,数据传输与存储的机密性,例如对于web应用来说,用户认证应该是最基础的东西。
·可扩展性
这个属性是滥用与模糊的,它指软件将来可以做现在还不能做的事情的能力,例如可以通过插件或API的方式实现某些需求的扩展。
·审计(可追溯性)
系统能够对重要数据或行为变化的事件进行记录,而需求明确这些变化由谁做出,什么时候做出,做出什么样的信息。
·其它非功能性需求
监测
管理
国际化
...
提炼非功能性需求
·从用户描述中提炼,例如从“系统一定要快”等关键字提炼性能需求并反馈回用户。
·从系统所在的业务领域中提炼,此部分在用户描述中被忽略而需要我们提出并反馈用户。
·尝试量化非功能性需求并能够可测