[software development] 需求分析checklist
[software development] 需求分析checklist
// */
// ]]>
[software development] 需求分析checklist
Table of Contents
1 Specific Functional Requirements, 功能上的需求
- Are all the inputs to the system specified, including their source, accuracy, range of values, and frequency?
是不是所有系统的输入都已经详细说明了, 包括输入源, 精度, 输入的范围, 以及不同输入的频率?
- Are all the outputs from the system specified, including their destination, accuracy, range of values, frequency, and format?
是不是所有系统的输出都已经详细说明了, 包括输出的地点, 精度, 数值的范围, 频率以及格式?
- Are all output formats specified for web pages, reports, and so on?
是不是所有的输出格式(用于网页, 报告等)都被详细说明了?
- Are all the external hardware and software interfaces specified?
是不是所有的外部的软件接口以及硬件接口都被详细说明了?
- Are all the external communication interfaces specified, including handshaking, error-checking, and communication protocols?
是不是所有的外部通信接口都被详细说明了, 包括握手协议, 错误检测, 以及通信协议
- Are all the tasks the user wants to perform specified?
是不是所有的用户相要的任务都被详细说明了?
- Is the data used in the each task and the data resulting from each task specified?
每一个任务的输入数据和输出结果是不是都被详细说明了?
2 Specific Non-Functional (Quality) Requirements, 非功能需求
- Is the expected response time, from the user's point of view, specified for all necessary operations?
从用户的角度看, 所有的必要操作的响应时间是否被详细说明了?
- Are other timing considerations specified, such as processing time, data-transfer rate, and system throughput?
其他的运行时间有没有被详细说明, 如处理时间, 数据传输率, 系统的吞吐量
- Is the level of security specified?
安全的级别有没有被详细说明?
- Is the reliability specified, including the consequences of software failure, the vital information that needs to be protected from failure, and the strategy for error detection and recovery?
可靠性有没有被详细说明, 包括软件错误的后果, 错误发生时关键信息的保护, 错误检测以及自我修复的策略?
- Is maximum memory specified?
最大的内存需求有没有被详细说明?
- Is the maximum storage specified?
最大的存储需求有没有被详细说明?
- Is the maintainability of the system specified, including its ability to adapt to changes in specific functionality, changes in the operating environment, and changes in its interfaces with other software?
系统的可维护性有没有被详细说明, 包括个别功能的改变, 操作环境的改变, 与其他软件之间的接口的改变等?
- Is the definition of success included? Of failure?
有没有说到什么程度算是成功, 怎样又叫做失败?
3 Requirements Quality, 需求的质量
- Are the requirements written in the user's language? Do the users think so?
需求是不是以用户能够理解的方式写的? 用户是这么认为的吗?
- Does each requirement avoid conflicts with other requriements?
每一个需求和其他的需求有没有冲突?
- Are acceptable trade-offs between competing attributes specified – for example, between robustness and correctness?
互相矛盾的特性之间有没有达到一个可以接受的平衡关系, 如稳健性和准确性之间?
- Do the requirements avoid specifying the design?
需求分析有没有避免详细的设计?
- Are the requirements at a fairly consistent level of detail? Should any requirement be specified in more detail? Should any requirement be specified in less detail?
是否有些需求过于细化, 或是不够细化?
- Are the requirements clear enough to be turned over to an independent group for construction and still be understood?
需求是否足够清晰, 清晰到能够让一个独立的小组充分理解需求, 并进行下一步的构件?
- Is each Item relevant to the problem and its solution? Can each item be traced to its origin in the problem environment?
每一项都与问题和结果相关吗? 能够将每一项追溯到原始问题?
- Is each requirement testable? Will it be possible for independent testing to determine whether each requirement bas been satisfied?
每个需求都能够被测试吗? 能否通过独立的测试确定各个需求的满足情况?
- Are all possible changes to the requriements specified, including the likelihood of each change?
所有可能引起需求改变的因素都详细说明了吗, 包括不同改变的可能性?
4 Requirements Completeness, 需求完成
- Where information isn't available before development begins, are the areas of incompleteness specified?
开发之前没有完成的需求是不是被详细说明了?
- Are the requirements complete in the sense that if the product satisfied every requirement, it will be acceptable?
当需求结束后, 确认产品是否能够满足所有的需求?
- Are you comfortable with all the requirements? Have you eliminated requirements that are impossible to implement and included just to appease your customer or your boss?
你对于所有的需求满足吗? 你是否要消除那些无法实现的或是为了迎合顾客或老板的需求呢?
5 出自
Code complete second edition
Date: 2014-04-23 Wed
Author: Zhong Xiewei
Org version 7.8.11 with Emacs version 24
[software development] 需求分析checklist的更多相关文章
- 关于敏捷开发方法(Agile Software Development)的阅读笔记
对“敏捷开发”(Agile Software Development)这个词,我是在这学期邹欣老师<现代程序设计>课上第一次听到的,刚听到时并不知道其具体指什么,只是从字面上直觉其意思应该 ...
- 敏捷软件开发 Agile software Development(转)
原文链接: http://www.cnblogs.com/kkun/archive/2011/07/06/2099253.html 敏捷软件开发 Agile software Development ...
- 敏捷软件工程(agile software development) VS传统软件工程(traditional software development)
敏捷软件工程(agile software development) VS传统软件工程(traditional software development) Agile principle ...
- Agile software Development
转自:https://www.cnblogs.com/kkun/archive/2011/07/06/agile_software_development.html 敏捷软件开发 Agile soft ...
- 软件开发流程 Software development process
软件开发流程(Software development process)即软件设计思路和方法的一般过程,包括设计软件的功能和实现的算法和方法.软件的总体结构设计和模块设计.编程和调试.程序联调和测试以 ...
- Software Development Engineer - Database Services
http://stackoverflow.com/jobs/116486/software-development-engineer-database-services-amazon?med=clc& ...
- 微软职位内部推荐-Software Development Engineer
微软近期Open的职位: Job Title: Software Development Engineer Work Location: Suzhou, China The Office 365 Co ...
- FBX Software Development Kit
FBX Software Development Kit The FBX Software Development Kit (FBX SDK) allows software developers t ...
- Agile Software Development ——敏捷开发
敏捷? 过去几年中,软件行业中出现了一个新词汇——agile:与此同时,一个关于新的软件开发方式的变革正悄然兴起. 在老师的引导下,我阅读了Agile Guide网站上的几篇文章,并查阅了相关资料.不 ...
随机推荐
- HashSet和HapMap取distinct value
public class TestHashSetAndHashMap { private final int setNum=5000; @Test public void doTest(){ List ...
- python输入输出
python 如何读取控制台输入的数据 比方说:从控制台读一个人的名字,赋给变量name 如下: name = input("name:") print(name) 如何读取一 ...
- Visual Studio2013(Update4)无法生成依赖项关系图解决方案
今天为了看别人写的一套框架,就琢磨着有没视图的方式去看别人每个类和方法之间的调用和继承关系.这个时候发现了一个VS2013自带的功能: 带着兴奋的心情小手一抖一点... 我等呀等,等呀等.... 尼玛 ...
- 单用户模式下修改root密码
1.重启或者开机时,在倒数3秒的界面按下任意键. 2.该界面有如下提示(e 编辑 a 更改内核选项 c 命令行 b 启动),所以我们按下"e"编辑. 3.上下键选中第二行再按下& ...
- linux OS install oracle database
#!/bin/bash#Purpose:Create and config oracle install.#Usage:Log on as the superuser('root') #1.creat ...
- JavaScript调试工具
最常用的最有效的有三个: 1. FireFox浏览器的Firebug,我用得不多 2. IE 8浏览器的Microsoft Script Editor.当运行网页的脚本出错时,会报错,如下所示: 单击 ...
- Asp.net vnext的IIS部署
微软前段时间推出asp.net vnext,自个也尝试了一把,也写了几篇关于vnext特性的博客,如下. 但一直有个困扰的问题,asp.net vnext如何在iis部署,因为整个目录结构跟之前有了很 ...
- EQueue - 一个C#写的开源分布式消息队列的总体介绍
前言 本文想介绍一下前段时间在写enode时,顺便实现的一个分布式消息队列equeue.这个消息队列的思想不是我想出来的,而是通过学习阿里的rocketmq后,自己用c#实现了一个轻量级的简单版本.一 ...
- $.ajax 跨域请求 Web Api
WepApi确实方便好用,没有配置文件,一个apicontroller直接可以干活了.但今天用$.ajax跨域请求的时候总是获取不到数据,用fiddler一看确实抓到了数据,但回到$.ajax函数中, ...
- Entity Framework 5.0系列之约定配置
Code First之所以能够让开发人员以一种更加高效.灵活的方式进行数据操作有一个重要的原因在于它的约定配置.现在软件开发越来复杂,大家也都试图将软件设计的越来越灵活,很多内容我们都希望是可配置的, ...