V模型 (软件开发)

✍ dations ◷ 2025-11-22 17:27:14 #软件工程,软件开发

软件开发中的V模型是一种延伸自瀑布模型的软件开发过程,是通用V模型的一个例子。V模型的软件开发不是以直线的方式进行,其过程在源代码阶段之前逐步往下,而在源代码阶段之后逐步往上,形成了V字形。V模型指出了软件开发中的各阶段以及其对应软件测试阶段之间的关系。横轴表示时间或是专案的完成度,而纵轴表示抽象的程度(范围越大,越抽象的在越上方)。

需求分析阶段是专案定义阶段中的第一个阶段,有些文献也称为是验证(verification)阶段的第一个阶段。此阶段要分析用户的需要,整理出系统的需求(英语:software requirements)(功能需求)。此阶段着重的是建构出要实现的理想系统,但不用决定软件的设计方式。一般而言,此阶段会和用户面谈,建立用户需求文件(user requirements document)。

用户需求文件会说明系统的功能、界面、性能、资料、安全性等,会列出客户预期的需求。企业分析师会用这个,配合其系统性的了解,来和用户沟通。用户会仔细的确认这些文件,因为文件是系统设计师的指南,也会在这个阶段规划用户验收测试。

在收集用户需求时,有许多不同的方式,常见的有访问、问卷、文件分析、观察、利用可丢弃的原型、用例等。

系统设计(英语:Systems design)是系统设计师根据用户需求文件,分析并理解要开发系统的业务流程的阶段。此阶段会列出要实现用户需求需要的技术以及可能性。若有些用户需求不可行,会反应给用户,针对此需求的最后处理方式也会列在用户需求文件中。

此阶段也会产生软件规格文件(software specification document),是开发阶段的蓝图,其中会包括大致的系统架构、指令选单结构、数据结构等,其中也会包括业务场景、样本视窗以及报表以帮助理解。此阶段也会产生实体图(entity diagrams)、数据字典等技术文件,并且整理系统测试的文件。

这个阶段会设计计算机系统结构及软件架构,也称为高阶设计。选择架构的基准是应该可以实现所有模组的列表、模组的简单机能、界面关系、相依性、数据库、数据库表、架构图、技术细节等。在这个阶段也会设计整合测试的内容。

模组设计阶段也称为低阶设计。会将设计的系统拆解为较小的单元或是模组,也会说明每一部分的内容,让程式设计者可以直接写程式。低阶设计文件或是程式规格书会包括模组的逻辑细节,可能会以伪代码的方式表示,也会有以下的内容:

单元测试会在此阶段进行规划。

在V模型中,验证(或专案定义)阶段中的每一阶段,在确认阶段都会有对应旳阶段。以下是V模型的验证阶段,不过也会使用其他的名称。

在V模型中,在模组设计阶段就会规划单元测试计划(Unit Test Plans)。单元测试计划的目的是要消除程式码层级及单元层级的错误。单元是程式中可以独立存在的最小程式体,例如程式模组。单元测试是验证最小的程式体在和其他程式隔离的情形下,是否可以正常运作。

整合测试的计划会在架构设计阶段订定。整合测试会验证这些独立创建、独立测试过的模组是否可以共存,互相交换讯息。整合测试的测试结果常会分享给用户的团队。

系统测试计划会在系统设计的阶段订定。系统测试不同于单元测试及整合测试。系统测试计划会由用户的团队来进行。系统测试会确保所开发的软件符合预期的需求,会测试整个软件的机能、相互依存以及通讯。系统测试也会验证系统符合机能需求以及非机能需求。像负载测试、性能测试、压力测试及回归测试等,都是系统测试的一部分。

用户验收测试(User Acceptance Test)计划会在需求分析阶段就订定。测试计划是由企业用户来进行。用户验收测试会在用户的环境下进行,设法模拟实际产品的环境,也会使用实际的数据。用户验收测试的目的是要确认所提供的系统符合客户需求,而且系统已可以在实际环境下使用。

敏捷软件开发倡议者对V模型有所批评,因为以下的原因,V模型不适合作为软件开发的模型:

V模型的支持者指出V模型也会逐渐进步,在开发过程中也可以有可变性,符合敏捷开发的原则。支持者认为V模型强调纪律、也提倡精细的设计、开发以及文件,这些都是要建构稳定软件产品时,必要的元素。近年来,V模型已用在医疗软件的开发上。

相关

  • ST节段ST节段(ST segment)为心电图学术语,表示QRS复合波(英语:QRS complex)至T波之间的间期,一般介于 0.005 至 0.150 秒之间(5 至 150 毫秒)。ST节段始于J点(英语:J-point)(即QRS复合波的终点),
  • GeckoGecko是一套自由及开放源代码、以C++编写的排版引擎,当前为Mozilla Firefox网页浏览器以及Mozilla Thunderbird电子邮件客户端等Mozilla基金会相关产品所使用。Gecko原本由网
  • 公共实体荷兰加勒比区(荷兰语:Caribisch Nederland)是属于荷兰本土的三个公共实体:博奈尔、圣尤斯特歇斯和萨巴的集体名称,又称BES群岛,其地名已在国际标准化组织的ISO 3166-1国际标准注册
  • 陆缘海缘海、陆陆缘海或称边陆缘海(英语:Marginal Sea)指的是大海的四周大部分是由半岛、岛屿或者陆地所环绕的大海;名称差异为陆缘海是地球科学名词,陆陆缘海是地质学名词,边陆缘海是海
  • 鲣鸟目Pseudosulidae鲣鸟科(学名:Sulidae)是鸟纲鲣鸟目中的一个科,包括三属。体长约65-85厘米的大型海鸟。广泛分布于太平洋、大西洋和印度洋。在海洋上空飞行寻找鱼群和鱿鱼。发现鱼
  • 颜色革命颜色革命(Color revolution),又称花朵革命,是指20世纪80、90年代开始的一系列发生在中亚、东欧独联体国家的以颜色命名,以“和平非暴力”方式进行的政权变更运动,而且这些运动有向
  • 蛮牛蛮牛是台湾保力达公司推出的机能性饮料,在台湾以及港澳地区贩售,是台湾提神饮料销售量的前几名之一。其广告用到的“你累了吗”也成为台湾的流行用语之一,廖嘉琛蛮牛先生为此系
  • HD 33948HD 33948(又名BD-08 1059、SAO 131887和HR 1704)是一颗恒星,视星等为6.37,位于银经209.07,银纬-25.44,其B1900.0坐标为赤经5h 8m 44.8s,赤纬-8° -25.44′ 56″。
  • 希波箭石见内文希波箭石(学名:)是生存在晚侏罗纪至中白垩纪海洋中的一属箭石。它们的护甲为细长矛头状,膨大处位于中央偏后,自此处向后逐渐变尖。闭锥内朝向口一侧的最外二个隔壁有穿孔,可
  • 纳霍德卡纳霍德卡(俄语:Нахо́дка),大清统治时期名为漤沟崴,是一个位于俄罗斯联邦滨海边疆区、面对日本海的不冻港,以军事设施与水产养殖为主,也是泰舍特-纳霍德卡输油管道(泰纳线)的东