什么是软件需求,什么是功能需求?——论需求的三个层次和三个方面(2)

原创 2010年04月20日 23:45:00

     我们的软件产品或者项目,其需求都有三个层级和三个方面。

     一、我们首先看需求的三个层次

     软件需求的层次

     软件需求包括3个不同的层次――业务需求、用户需求和功能需求。

  业务需求(Business requirement)表示组织或客户高层次的目标。业务需求通常来自项目投资人、购买产品的客户、实际用户的管理者、市场营销部门或产品策划部门。业务需求描述了组织为什么要开发一个系统,即组织希望达到的目标。使用前景和范围(vision and scope)文档来记录业务需求,这份文档有时也被称作项目轮廓图或市场需求(project charter 或 market requirement)文档。
  用户需求(user requirement)描述的是用户的目标,或用户要求系统必须能完成的任务。用例、场景描述和事件――响应表都是表达用户需求的有效途径。也就是说用户需求描述了用户能使用系统来做些什么。
  功能需求(functional requirement)规定开发人员必须在产品中实现的软件功能,用户利用这些功能来完成任务,满足业务需求。功能需求有时也被称作行为需求(behavīoral requirement),因为习惯上总是用“应该”对其进行描述:“系统应该发送电子邮件来通知用户已接受其预定”。功能需求描述是开发人员需要实现什么。注意:用户需求不总是被转变成功能需求。产品特性,所谓特性(feature),是指一组逻辑上相关的功能需求,它们为用户提供某项功能,使业务目标得以满足。对商业软件而言,特性则是一组能被客户识别,并帮助他决定是否购买的需求,也就是产品说明书中用着重号标明的部分。客户希望得到的产品特性和用户的任务相关的需求不完全是一回事。一项特性可以包括多个用例,每个用例又要求实现多项功能需求,以便用户能够执行某项任务。

  系统需求(system requirement)用于描述包含有多个子系统的产品(即系统)的顶级需求。系统可以只包含软件系统,也可以既包含软件又包含硬件子系统。人也可以是系统的一部分,因此某些系统功能可能要由人来承担。
  业务规则包括企业方针、政府条例、工业标准、会计准则和计算方法等。业务规划本身并非软件需求,因为它们不属于任何特定软件系统的范围。然而,业务规则常常会限制谁能够执行某些特定用例,或者规定系统为符合相关规则必须实现某些特定功能。有时,功能中特定的质量属性(通过功能实现)也源于业务规则。所以,对某些功能需求进行追溯时,会发现其来源正是一条特定的业务规则。
  功能需求记录在软件需求规格说明(SRS)中。SRS完整地描述了软件系统的预期特性。SRS我们一般把它当作文档,其实,SRS还可以是包含需求信息的数据库或电子表格;或者是存储在商业需求管理工具中的信息;而对于小型项目,甚至可能是一叠索引卡片。开发、测试、质量保证、项目管理和其他相关的项目功能都要用到 SRS。

     除此之外,对于需求层次,我们还有其它的分法:

     组织级需求->业务需求->用户需求->功能需求(有时也叫行为需求)。

     组织级需求:一般代表着组织的愿景和目标。对于大的公司,一般是通过资深的咨询顾问和咨询公司得出的,呈现的方式是咨询报告。比如在ITSM或者企业信息化这方面。典型的组织级的需求是:降低成本、减少库存成本、提升IT服务部门在企业中的价值、通过ISO20000、提高IT服务的效率、提高员工的满意度等。

     业务需求:是要完组织的使命,达成组织的愿景的各个业务流程和业务单元具有的需求。业务需求服从于组织需求。

     用户需求:用户级的需求,是在业务级的需求下,各个岗位协作完成业务而具有的需求。我们在软件需求规格说明书中表述的需求其实主要是这一部分需求。

     功能需求:同样,它代表着产品或者软件需求具备的能力。 一般是管理人员或者产品的市场部门人员负责定义软件的业务需求,以提高公司的运营效率(对信息系统而言)或产品的市场竞争力(对商业软件而言)。所有的用户需求都必须符合业务需求。需求分析员从用户需求中推导出产品应具备哪些对用户有帮助的功能。开发人员则根据功能需求和非功能需求设计解决方案,在约束条件的限制范围内实现必需的功能,并达到规定的质量和性能指标。当一项新的特性、用例或功能需求被提出时,需求分析员必须思考一个问题:“它在范围内吗?”。如果答案是肯定的,则该需求属于需求规格说明,反之则不属于。但答案也许是“不在,但应该在”,这时必须由业务需求的负责人或投资管理人来决定:是否扩大项目范围以容纳新的需求。这是一个可能影响项目进度和预算的商业决策。

     二、需求的三个方面
  除了功能需求外,SRS中还包含非功能需求,包括性能指标和对质量属性的描述。

    
  质量属性(quality attribute)对产品的功能描述作了补充,它从不同方面描述了产品的各种特性。这些特性包括可用性、可移植性、完整性、效率和健壮性,它们对用户或开发人员都很重要。其他的非功能需求包括系统与外部世界的外部界面,以及对设计与实现的约束。还有一项称为可用性(usability)的质量属性,它规定了业务需求中“有效”(efficiently)一词的含义。
  约束(constraint)限制了开发人员设计和构建系统时的选择范围。约束,在产品的架构设计中,是需要被首先考虑的问题。

     如果说产品的功能代表了产品的能力,那么产品的质量属性代表了产品的品质,产品的约束代表了产品必须去满足的或者适应的条件!用人说“用户体验”是产品的灵魂,对于个人级的软件这么说或许很恰当,当对于企业级甚至是行业级的产品,其灵魂有两个:一个是产品带个用户的价值,另一个是产品的品质,简单的说,就是价值和品质。但其成为一个产品的前提应该是满足约束,否则就不应该设计、开发、进入市场而成为一个垃圾。
  

 

软件需求三个层次

软件需求分为三个层次:业务需求、用户需求和功能需求。     1、业务需求(Why):反映了组织机构或客户对系统、产品的高层次的目标追求,定义了项目的远景和范围,即确定了项目的发展方向、功能范围、目标...
  • u010233287
  • u010233287
  • 2015-04-22 19:06:44
  • 969

软件工程中需求的三个不同层次

软件需求包括3个不同的层次――业务需求、用户需求和功能需求。   除此之外,每个系统还有各种非功能需求。   业务需求(Business requirement)表示组织或客户高层次的目标。业...
  • larry_lv
  • larry_lv
  • 2011-09-15 09:53:03
  • 837

软件需求的定义

软件需求的定义  软件行业存在这样一个问题,用于描述需求工作的术语没有统一的定义。对同一项需求,不同的人会有不同的描述,称其为用户需求、软件需求、功能需求、系统需求、技术需求、业务需求或产品需求。客户...
  • vinglemar
  • vinglemar
  • 2008-03-13 08:49:00
  • 7689

什么是软件需求?软件需求是什么意思?

  什么是软件需求?软件需求是什么意思?   对大多数人来说,若要建一幢数百万元的房子,他一定会与建房者详细讨论各种细节,他们都明白完工以后的修改会造成损失,以及变更细节的危害性。然而,涉及到软件开发...
  • alanytam
  • alanytam
  • 2008-05-22 11:29:00
  • 1419

什么是软件需求?什么是功能需求?

我们的软件产品或者项目,其需求都有三个层级和三个方面。 一、我们首先看需求的三个层次 软件需求包括3个不同的层次――业务需求、用户需求和功能需求。 业务需求 (Business requiremen...
  • finish_dream
  • finish_dream
  • 2016-04-17 15:40:17
  • 2872

什么是软件需求,软件需求的分类

软件需求包括3个不同的层次――业务需求、用户需求和功能需求。原链接地址 1、业务需求 (Business requirement)表示组织或客户高层次的目标。业务需求通常来自项目投资人、...
  • ly_fhrl
  • ly_fhrl
  • 2016-04-27 10:22:01
  • 1732

需求用例分析之四:业务规则

在雅各布森用例分析方法和科伯恩用例分析方法中其实都没有“业务规则”的属性,在科伯恩方法中有个相近的属性是约束条件。但是业界使用中常常会给用例加上这个属性,这是为什么呢?为什么两位大师没有加上,是大师们...
  • zhangmike
  • zhangmike
  • 2014-05-24 21:01:05
  • 6706

什么是软件需求,什么是功能需求?——论需求的三个层次和三个方面(2)

     我们的软件产品或者项目,其需求都有三个层级和三个方面。     一、我们首先看需求的三个层次          软件需求包括3个不同的层次――业务需求、用户需求和功能需求。  业务需求(Bu...
  • qinhl99
  • qinhl99
  • 2010-04-20 23:45:00
  • 6784

软件需求分层处理的多种常见方式

当前的需求 常见分 几个层次来管理? 原先的SRS只有一个层次,在瀑布型生命周期中发挥了重要作用,需求里程碑评审和需求变更管理都是围绕着SRS来进行的。随着时间推移,瀑布型生命周期的弊端越来越明显,而...
  • zhangmike
  • zhangmike
  • 2015-10-31 07:36:05
  • 2372

什么是软件需求,什么是功能需求?

转自:http://blog.csdn.net/qinhl99/archive/2010/04/20/5509004.aspx我们的软件产品或者项目,其需求都有三个层级和三个方面。     一、我们首...
  • johnstrive
  • johnstrive
  • 2010-12-15 16:10:00
  • 1574
收藏助手
不良信息举报
您举报文章:什么是软件需求,什么是功能需求?——论需求的三个层次和三个方面(2)
举报原因:
原因补充:

(最多只允许输入30个字)