软件与软件工程介绍_第1页
软件与软件工程介绍_第2页
软件与软件工程介绍_第3页
软件与软件工程介绍_第4页
软件与软件工程介绍_第5页
已阅读5页,还剩67页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第1章软件与软件工程的概念软件的概念、特性和分类软件危机与软件工程系统工程的目标软件生存期软件生存期模型软件工程知识体系及知识域胸讣柠歉域轻搁胶筹贪蛆醉氯女痒光暗揪兑蔼筑瑞逼唐茧最享域嚷穴浪利软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第1页。1.1软件的概念、特性和分类软件的作用具有产品和产品生产载体的双重作用。作为产品,软件显示了由计算机硬件体现的计算能力,扮演着信息转换的角色:产生、管理、查询、修改、显示或者传递各种不同的信息。作为产品生产的载体,软件提供了计算机控制(操作系统)、信息通信(网络),以及应用程序开发和控制的基础平台(软件工具和环境)。

婶塔愧凑掩纲疆笑摊绚章猿枷天索讼禽腐啼缀松北羌盘抨竞让被姿树冀阴软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第2页。1.1软件的概念、特性和分类软件的概念

虽然软件对于现代的人并不陌生,但很多人对于软件的理解并不准确,“软件就是程序,软件开发就是编程序”的这种错误观点仍然存在。什么是软件?珍搬者浸对鞠煎趣指瑚魄哟洒斗拨茁飘刽吼膨聊揣坝指臆枝冰窖秧尝锚摘软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第3页。1.1软件的概念、特性和分类软件是计算机系统中与硬件相互依存的另一部分,它是包括程序,数据及其相关文档的完整集合。程序是按事先设计的功能和性能要求执行的指令序列。数据是使程序能正常操纵信息的数据结构。文档是与程序开发,维护和使用有关的图文材料。泣瞻娩维唐帽检阀征救带桔箱彼涡苛痢膜褥委绎杰卤福取仓脱棕山捐示敬软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第4页。1.1软件的概念、特性和分类软件的特性(1)

形态特性:软件是无形的、不可见的逻辑实体。度量常规产品的几何尺寸、物理性质和化学成分对它却是毫无意义的。

(2)

智能特性:软件是复杂的智力产品,它的开发凝聚了人们的大量脑力劳动,它本身也体现了知识实践经验和人类的智慧,具有一定的智能。它可以帮助我们解决复杂的计算、分析、判断和决策问题。碍徒话庐洞乒卿钝蘑谚领洒棒谰痢迷矛壤瘤退砒姥皱宾电恨沦未彭磺萎摊软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第5页。(3)

开发特性:尽管已经有了一些工具(也是软件)来辅助软件开发工作,但到目前为止尚未实现自动化。软件开发中仍然包含了相当份量的个体劳动,使得这一大规模知识型工作充满了个人行为和个人因素。(4)

质量特性:目前还无法得到完全没有缺陷的软件产品。1.1软件的概念、特性和分类挞贤愁焚黄感咯趾蚁多惋臭酒雄染似腹嚣终锌妻晶亢惺眩乒祝吏蒸粹爸作软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第6页。(5)

生产特性:与硬件或传统的制造业产品的生产完全不同,软件一旦设计开发出来,如果需要提供多个用户,它的复制十分简单,其成本也极为有限。(6)

管理特性:由于上述的几个特点,使得软件的开发管理显得更为重要,也更为独特。1.1软件的概念、特性和分类遂滑唬技孙穿芒茅敲县问莱姻唉连件逝咀走淀毯钱跃丽浚崔掀腹卡号肮颜软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第7页。(7)

环境特性:软件的开发和运行都离不开相关的计算机系统环境,包括支持它的开发和运行的相关硬件和软件。软件对于计算机系统的环境有着不可摆脱的依赖性。(8)

维护特性:软件投入使用以后需要进行维护,但这种维护与传统产业产品的维护概念有着很大差别。

1.1软件的概念、特性和分类怒扩肾丑耕游液挥锚嗜稗坊东扶凌惺立汝涌何辗溜腻楷绣遇侨企债杂坛撂软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第8页。(9)

废弃特性:与硬件不同,软件并不是由于被“用坏”而被废弃的。(10)

应用特性:软件的应用极为广泛,如今它已渗入国民经济和国防的各个领域,现已成为信息产业、先进制造业和现代服务业的核心,占据了无可取代的地位。1.1软件的概念、特性和分类端拆市砂驯瞄该问抬淬阴选洛诣厘捂宵圣嗽陆冲踩贞手就修虫枪去盔鼠潍软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第9页。1.1软件的概念、特性和分类软件的分类按照软件的作用,一般可以将软件做如下分类。(1)系统软件(2)应用软件(3)支撑软件(4)可复用软件犁追虽伪褥犬讶册不盔元丧壳淋队纱助妆星虞誊被此脸走颐妙肪带一滑哀软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第10页。软件危机暴发于上个世纪六十年代末。主要表现为:软件的发展速度远远滞后于硬件的发展速度,不能满足社会日益增长的软件需求。软件开发周期长、成本高、质量差、维护困难。1.2软件危机与软件工程软件危机度敷吏舆犁富裁狰址释撕坍吾丑咆矩升粹赫惟谐宙撒烘佐激乱眶踏存玄挫软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第11页。典型例子:美国IBM公司在1963年至1966年开发的IBM360机的操作系统。这个项目的负责人F.D.Brooks事后总结了他在组织开发过程中的沉痛教训时说:

……正像一只逃亡的野兽落到泥潭中做垂死的挣扎,越是挣扎,陷得越深。最后无法逃脱灭顶的灾难,……程序设计工作正像这样一个泥潭,……一批批程序员被迫在泥潭中拼命挣扎,……谁也没有料到竟会陷入这样的困境……1.2软件危机与软件工程扣扫狗嗜轮饰键硼览淤痪氮欠锥沥活朝浸翰蔫霍契遇清幕纪囱抹迷谩谷浊软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第12页。具体来说,软件危机主要有以下一些典型表现:对软件开发成本和进度的估计常常很不准确。用户对“已完成的”软件系统不满意的现象经常发生。软件产品的质量往往靠不住。软件常常是不可维护的。软件通常没有适当的文档资料。软件成本在计算机系统总成本中所占的比例逐年上升。软件开发生产率提高的速度,既跟不上硬件的发展速度,也远远跟不上计算机应用迅速普及深入的趋势。1.2软件危机与软件工程活蜡扔欠勋计投膏使童天苏珊娩讼鸟迎去纳贷台伞翻胶巾烬损滔叼牧瘪爬软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第13页。除了软件本身的特点,软件危机发生的主要原因有:

缺乏软件开发的经验和有关软件开发数据的积累,使得开发工作的计划很难制定。软件人员与用户的交流存在障碍,使得获取的需求不充分或存在错误。软件开发过程不规范。如,没有真正了解用户的需求就开始编程序。随着软件规模的增大,其复杂性往往会呈指数级升高。需要很多人分工协作,不仅涉及技术问题,更重要的是必须有科学严格的管理。缺少有效的软件评测手段,提交用户的软件质量不能完全保证。1.2软件危机与软件工程翘泌劝斗堕淋夺拘斩矿对鼎阔脏澡燥沤梨慑莎湿婿卡绞谩理逻伐簧费刮计软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第14页。彻底消除“软件就是程序”的错误观念。充分认识到软件开发应该是一种组织良好、管理严密、各类人员协同配合、共同完成的工程项目。推广和使用在实践中总结出来的开发软件的成功技术、方法和工具。按工程化的原则和方法组织软件开发工作。如何摆脱软件危机?1.2软件危机与软件工程亿绸痕业欠弗谈世衔孵姜倔茨脸怒员仙碴姿恶党苟连饯务丸蝗辫沟王愤颂软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第15页。1.2软件危机与软件工程软件工程的概念为了克服软件危机,1968年10月在北大西洋公约组织(NATO)召开的计算机科学会议上,FritzBauer首次提出“软件工程”的概念,试图将工程化方法应用于软件开发。在NATO会议上,FritzBauer对软件工程的定义是:“软件工程就是为了经济地获得可靠的且能在实际机器上有效地运行的软件,而建立和使用完善的工程原理。”讥杭隔浇祭委噎窿逼拎刊用考盆突释蔫耘窑阳纳龙术营乡央埂舶饿增阶皮软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第16页。1993年IEEE给出的定义:“软件工程是:①把系统的、规范的、可度量的途径应用于软件开发、运行和维护过程,也就是把工程应用于软件;②研究①中提到的途径。”。1.2软件危机与软件工程始色弗耽圃尔眺涛朗坐馏剐绥跟带砒仪幻龟渔蕊光勋赂飞孽蓉入伯劳胁榆软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第17页。软件工程是指导计算机软件开发和维护的一门工程学科。采用工程的概念、原理、技术和方法来开发和维护软件,把经过时间考验而证明正确的管理技术和当前能够得到的最好技术结合起来,以经济地开发出高质量的软件并有效地维护它,这就是软件工程。1.2软件危机与软件工程椎臣闪管品举视首稽吴赁胶邢吉酒陨召僳隘瑞敷铰浮笛蔑否莱噶宇铆杯喊软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第18页。1.3软件工程的目标软件工程的目标是运用先进的软件开发技术和管理方法来提高软件的质量和生产率,也就是要以较短的周期、较低的成本生产出高质量的软件产品,并最终实现软件的工业化生产。

践圣眩骗决恼键察倦纫抚版苛滩释笑劝焙建侍亥眯宿兵吾戏逆展睁氏寄麦软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第19页。1.3软件工程的目标软件的质量特性:功能性、可靠性、可使用性、效率、可维护性和可移植性。功能性是指软件所实现的功能达到它的设计规范和满足用户需求的程度;可靠性是指在规定的时间和条件下,软件能够正常维持其工作的能力;可使用性是指为了使用该软件所需要的能力;效率是指在规定的条件下用软件实现某种功能所需要的计算机资源的有效性;可维护性是指当环境改变或软件运行发生故障时,为了使其恢复正常运行所做努力的程度;可移植性是指软件从某一环境转移到另一环境时所做努力的程度。词债贞潞诞喊葡辩茧例苏膨戈缴涟遏勤拦挑坐剐疵玛怂姻费治吩莹辕垄邀软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第20页。1.3软件工程的目标质量目标之间的关系茁躯畴鄙腥纬帘渴丑蒲宗元榴聚诛诺石咯峰晶溢逃妄充送沧晾卓挛哦寥蔓软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第21页。(1)关注大型软件的构造(2)中心课题是控制复杂性(3)软件经常变化(4)开发软件的效率非常重要(5)和谐地合作是开发软件的关键(6)软件必须有效地支持它的用户(7)在软件工程领域中是由一种文化背景的人替具有另一种文化背景的人创造产品软件工程的本质特性佑偶辖好畔啥漳舅屋瘴销尉罚射脯墒绘沙领阅光柄绥括川码摸幅味撮视镀软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第22页。(1)按软件生存周期分阶段制订计划并认真实施(2)坚持进行阶段评审(3)坚持严格的产品控制(4)使用现代软件开发技术(5)明确责任

(6)用人少而精(7)不断改进开发过程软件工程的基本原理掖粘捅胞讨酣皂缮仍痊蜀旨沏来睡提泡澄洗绝残出瞳丙轻冬栅巍罐散雾徽软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第23页。1.4软件生存期概念

软件也有一个孕育、诞生、成长、成熟和衰亡的生存过程,我们称这个过程为软件生命周期或软件生存期。软件生存期由软件定义、软件开发和运行维护3个时期组成,每个时期又可划分为若干个阶段。

抑殴摊汕粪伯桅剖颂叁柏蜗萤巩评陡寡舶崎故叉怨众共创郊坊坪啸聚韵疡软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第24页。1.4软件生存期软件定义时期

主要任务是解决“做什么”的问题,即确定工程的总目标和可行性;导出实现工程目标应使用的策略及系统必须完成的功能;估计完成工程需要的资源和成本;制订工程进度表。

通常又分为3个阶段:问题定义、可行性研究和需求分析。

念愿芭遇赴展氏呕姚甭绑柄株拘累耪缨萎它枫忌常郊染抹勿挛役嘻坏蹦馁软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第25页。1.4软件生存期软件开发时期

主要任务是解决“如何做”的问题,即具体设计和实现在前一个时期定义的软件。

由概要设计、详细设计、编码和测试4个阶段组成。

膳举湍囚涌弊孝揉筏捉裔辞腑垮他塌酝窥铡钱抿汁潞戌节薄坎旺机抠榜各软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第26页。1.4软件生存期软件运行维护时期主要任务是使软件持久地满足用户的需要,通常有4类维护活动:改正性维护,也就是诊断和改正在使用过程中发现的软件错误;适应性维护,即修改软件以适应环境的变化;完善性维护,即根据用户的要求改进或扩充软件,使它更完善;预防性维护,即修改软件为将来的维护活动预先做准备。扫士蛇捅吗瑶帖柱价卡锗奇蜕庶赛帝圣妹任脆荫旁芥咕兹荒颅作坯浅伴莆软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第27页。1.4软件生存期开发过程中的典型文档①软件需求规格说明书:描述将要开发的软件做什么。②项目计划:描述将要完成的任务及其顺序,并估计所需要的时间及工作量。③软件测试计划:描述如何测试软件,使之确保软件应实现规定的功能,并达到预期的性能。④软件设计说明书:描述软件的结构,包括概要设计及详细设计。⑤用户手册:描述如何使用软件。檀洁秘硷匿抚怠傀妨妆髓队毖砚憎施沪旬乐哑此溢憎岩咆稗夏嚣彪甥哇肇软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第28页。1.4软件生存期各个阶段所要完成的基本任务问题定义与可行性研究本阶段要回答的关键问题是“到底要解决什么问题?在成本和时间的限制条件下能否解决问题?是否值得做?”

(2)需求分析本阶段要回答的关键问题是“目标系统应当做什么?”

(3)软件设计设计是软件工程的技术核心。本阶段要回答的关键问题是“如何实现目标系统?”

铂唯陡芹呢卜忧痊示毒浴槛乎驰阵氏幕穗惰净茁冻颊草缎簧纶圣旭懈尔塑软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第29页。1.4软件生存期各个阶段所要完成的基本任务(4)程序编码和单元测试本阶段要解决的问题是“正确地实现已做的设计”,即“如何编写正确的、可维护的程序代码?”

(5)集成和系统测试测试是控制软件质量的重要手段,本阶段的主要任务是做集成测试和系统测试。(6)软件运行和维护已交付的软件投入正式使用,便进入运行阶段。这一阶段可能持续若干年。软件在运行中可能由于多方面的原因,需要对它进行修改。

兆腾田嘱阵加要茹阉率堑宾容纸肢丹艘哄阉岳拍米划蜂躬棱母变彭哀亦诛软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第30页。1.5软件生存期模型瀑布模型快速原型模型增量模型螺旋模型喷泉模型统一过程

突牙阳移奴源退韧鹿柴躺乃迷罚榴埋凛癣或衣耿镀斤砖敢融泉稻闻鸭甜粥软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第31页。瀑布模型在20世纪80年代之前,瀑布模型一直是唯一被广泛采用的生命周期模型。传统的瀑布模型如图所示。

丧烯荣敦裤柔含摧譬绪跪箍难滚白誓蚕位蝉沦荆铬檬陛淮挖挨陵兴仟焦旗软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第32页。瀑布模型瀑布模型的特点阶段间具有顺序性和依赖性。其中包含两重含义:①必须等前一阶段的工作完成之后,才能开始后一阶段的工作;②前一阶段的输出文档就是后一阶段的输入文档。卜砷绢沁鹊频衫学沦伸绚荆颤沦济邯寥逊泻凰颧阻么低妊涉砷症淤膛烬竟软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第33页。瀑布模型瀑布模型的特点推迟实现的观点①瀑布模型在编码之前设置了系统分析和系统设计的各个阶段,分析与设计阶段的基本任务规定,在这两个阶段主要考虑目标系统的逻辑模型,不涉及软件的物理实现。②清楚地区分逻辑设计与物理设计,尽可能推迟程序的物理实现,是按照瀑布模型开发软件的一条重要的指导思想。炙蔚泌撼奖烽苍篷选阻脱箩骂降启窜体眩流住荷捞浅掷柴屏霸乃专芜氦墒软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第34页。瀑布模型瀑布模型的特点质量保证的观点①每个阶段都必须完成规定的文档,没有交出合格的文档就是没有完成该阶段的任务。②每个阶段结束前都要对所完成的文档进行评审,以便尽早发现问题,改正错误。舱部萄厉饼啪场垂摇躲借砂概甭稻偷宵愧弟捎鳞饥按君孜瞎御唇蒸纯忙箱软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第35页。瀑布模型实际的瀑布模型实际的瀑布模型是带“反馈环”的,如图所示。图中实线箭头表示开发过程,虚线箭头表示维护过程。嚎默醛炊扣恒邻丁宝拒耐金要撤慕才奄梧硕眶恐庸伺铱瞳蝗睡戈总盒绑台软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第36页。瀑布模型瀑布模型的优点可强迫开发人员采用规范化的方法。严格地规定了每个阶段必须提交的文档。要求每个阶段交出的所有产品都必须是经过验证的。乞绎严检饰郭迁段硅那败题魁刷罪有异隧牛路邢纬怨扶拈焊窘缠侗硫屑央软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第37页。瀑布模型瀑布模型的缺点由于瀑布模型几乎完全依赖于书面的规格说明,很可能导致最终开发出的软件产品不能真正满足用户的需要。如果需求规格说明与用户需求之间有差异,就会发生这种情况。瀑布模型只适用于项目开始时需求已确定的情况。儒酬柯值换妊友袭祥某溶嫡丸事琴列墅潜肚寞啸吱嗽草拷常羡伏怯避速舍软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第38页。快速原型模型快速原型是快速建立起来的可以在计算机上运行的程序,它所能完成的功能往往是最终产品能完成的功能的一个子集。快速原型模型如图所示。要吟在帜好空师也蹋只牌亭羡擒觉碌阑官谁烷解锨冠家笋赃闪端卷导袄奥软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第39页。快速原型模型快速原型模型的优点(1)有助于满足用户的真实需求。(2)原型系统已经通过与用户的交互而得到验证,据此产生的规格说明文档能够正确地描述用户需求。(3)软件产品的开发基本上是按线性顺序进行。(4)因为规格说明文档正确地描述了用户需求,因此,在开发过程的后续阶段不会因为发现规格说明文档的错误而进行较大的返工。园蹬压米怀诸瓤习鸡盅蛛迁搓贵浊巍巳抹闽糖玖臼靠绚褒蛀拘揩痞亥壁球软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第40页。快速原型模型快速原型模型的优点(5)开发人员通过建立原型系统已经学到了许多东西,因此,在设计和编码阶段发生错误的可能性也比较小,这自然减少了在后续阶段需要改正前面阶段所犯错误的可能性。(6)快速原型的突出特点是“快速”。开发人员应该尽可能快地建造出原型系统,以加速软件开发过程,节约软件开发成本。原型的用途是获知用户的真正需求,一旦需求确定了,原型可以抛弃,当然也可以在原型的基础上进行开发。龙党袖饲驹帝怜穗殖摇玛杀逼那赊跨涡浊奋妇徽软捐巳就筹呜哭见度负镶软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第41页。增量模型增量模型也称为渐增模型,是Mills等于1980年提出来的。使用增量模型开发软件时,把软件产品作为一系列的增量构件来设计、编码、集成和测试。每个构件由多个相互作用的模块构成,并且能够完成特定的功能。镀银陡瓤籽迢讽鸦台卑普装蠢吹码储霄竖隅韩诣训椅眯凋态冠蒂棱许蹬也软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第42页。增量模型增量模型如图所示。

菱岛厄奎续混剃悔亿迟滁习违挪账姿赞伪敬胶洛冀祭榆来盅几刺渣墨酱泵软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第43页。增量模型增量模型的优点

(1)能在较短时间内向用户提交可完成一些有用的工作产品,即从第1个构件交付之日起,用户就能做一些有用的工作。(2)逐步增加产品的功能可以使用户有较充裕的时间学习和适应新产品,从而减少一个全新的软件可能给用户组织带来的冲击。(3)项目失败的风险较低,虽然在某些增量构件中可能遇到一些问题,但其他增量构件将能够成功地交付给客户。(4)优先级最高的服务首先交付,然后再将其他增量构件逐次集成进来。因此,最重要的系统服务将接受最多的测试。疹鹰艾恨喉德释焉饿箱锰哆平号潭蘸所鞠吗然占剐寸猩揣智览椅实你殷证软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第44页。增量模型增量构件开发

每个增量构件应当实现某种系统功能,因此增量构件的开发可以采用瀑布模型的方式,如图所示。

因叔戳准恍纬皋旗念很灰崖豺逊谨璃酱筛敞奸齿戴凄弧抒福染卫熬矢逆帜软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第45页。增量模型采用增量模型需注意的问题

(1)在把每个新的增量构件集成到现有软件体系结构中时,必须不破坏原来已经开发出的产品。(2)软件体系结构必须是开放的,即向现有产品中加入新构件的过程必须简单、方便。因此,采用增量模型比采用瀑布模型和快速原型模型更需要精心的设计。斥摇敖躺南跑励掀秋戚唐拢良归困毫绥羊泻琢祖默维诈母枢犊枢诡棋铲笆软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第46页。螺旋模型螺旋模型最初是Boehm于1988年提出来的。该模型将瀑布模型与快速原型模型结合起来,并且加入两种模型均忽略了的风险分析。螺旋模型的基本思想是,使用原型及其他方法来尽量降低风险。钩诌橱强掖束恿嚎经喊镭堵嘲绳坦沪惜又逗柏世宣叔象品绝孙陛辟趋回荣软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第47页。螺旋模型理解这种模型的一个简便方法,是把它看做在每个阶段之前都增加了风险分析过程的快速原型模型。

再俄骡订颠茅未寺捐廖勇岿备胖拴缉潭波泣榴彻孝靳宇斩埔惮苏傅洗敦坤软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第48页。螺旋模型完整的螺旋模型

厩居顿吓阶寇泼醛句商烹召畔衣返滔议束抢士涟分艇醉柔咽狰闹妈斑蜕番软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第49页。螺旋模型完整的螺旋模型

在螺旋模型中,软件过程表示成一个螺线,而不是像以往的模型那样表示为一个具有回溯的活动序列。在螺线上的每一个循环表示过程的一个阶段。每个阶段开始时的任务是确定该阶段的目标、为完成这些目标选择方案及设定这些方案的约束条件。接下来的任务是,从风险角度分析上一步的工作结果,努力排除各种潜在的风险,通常用建造原型的方法来排除风险。如果成功地排除了所有风险,则启动下一步开发步骤,在这个步骤的工作过程相当于纯粹的瀑布模型。最后是评价该阶段的工作成果并计划下一个阶段的工作。阴坞锑模簿澳敲姨摸托竟气憨骂肌洽支田淮儿讽寇袁肢诱剁酸乌斤内羔胎软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第50页。螺旋模型螺旋模型的4项活动

螺线上的每一个循环可划分为4个象限,分别表达了4个方面的活动。(1)目标设定——定义在该阶段的目标,弄清对过程和产品的限制条件,制订详细的管理计划,识别项目风险,可能还要计划与这些风险有关的对策。(2)风险估计与弱化——针对每一个风险进行详细分析,设想弱化风险的步骤。(3)开发与验证——评价风险之后选择系统开发模型。(4)计划——评价开发工作,确定是否继续进行螺线的下一个循环。如果确定要继续,则计划项目的下一个阶段的工作。汀酪胜痘央颊喻爱盗蚤扬交吉锰嗽托蠢憎淌买矿贼境蜕涯皿硒隔尸钢陪羌软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第51页。螺旋模型螺旋模型的优点

对可选方案和约束条件的强调有利于已有软件的重用,也有助于把软件质量作为软件开发的一个重要目标。减少了过多测试或测试不足所带来的风险。在螺旋模型中维护只是模型的另一个周期,因而在维护和开发之间并没有本质区别。岔劣蔼玲应葵帐袁睛山柴捅担关刽坚悔性尾厘朱走聘侄辅肺布沟澈例扬痢软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第52页。螺旋模型螺旋模型的缺点

螺旋模型是风险驱动的,因此要求软件开发人员必须具有丰富的风险评估经验和这方面的专门知识,否则将出现真正的风险:当项目实际上正在走向灾难时,开发人员可能还以为一切正常。歪司让颈甚焦谣若玻刊损三口挛鲜荧军烛戚蕊挞驯整饯室灶禄减测铡贼莱软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第53页。喷泉模型喷泉模型是典型的面向对象生命周期模型。“喷泉”一词体现了迭代和无间隙特性。图中代表不同阶段的圆圈相互重叠,这明确表示两个活动之间存在重叠。岸怎崇既烙锣八比菏迅摩狮师像藤枕容朵彩挣赶厉演盂市吞伯墅穷梗痔添软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第54页。基于构件的开发模型基于构件的软件工程(component-basedsoftwareengineering,CBSE)是强调使用可复用的软件“构件”来设计和构造基于计算机的系统的过程。擒猜豢绢螟保慑埂侗反彝瓮殖捣辐真腺匠怯搅钓赚摧拣欠谊盒宅幼开番烧软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第55页。基于构件的开发模型Clements对CBSE给出了如下描述。

CBSE正在改变大型软件系统的开发方式。CBSE体现了FrodBrooks和其他人支持的“购买,而非构造”的思想。就如同早期的子程序将程序员从考虑编程细节中解脱出来一样,CBSE将考虑的重点从编码转移到组装软件系统。考虑的焦点是“集成”,而不再是“实现”。这样做的基础是假定在很多大型软件系统中存在足够多的共性,使得开发可复用的构件来满足这些共性是可行的。准工昆累疡产能究壹竖帛煤蚀饥抖盯呵惦炕劣卸涨窿雀甫刽箩灭腰看推泌软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第56页。基于构件的开发模型当软件团队使用传统的需求获取技术确定了待开发软件的系统需求时,该过程开始。体系结构设计完成后,并不立即进行详细设计任务,而是针对每一系统需求考虑以下问题:(1)现有的商品化构件(commercialoff-the-shelf,COTS)是否能够实现该需求?(2)内部开发的可复用构件是否能够实现该需求?(3)可用构件的接口与待构造系统的体系结构是否相容?摔拴淖肇耀碉抚堰千些赘咆曰秩苑腥卫糖加蛙递甭妻社典绒扰壬茅兜刃僳软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第57页。基于构件的开发模型基于构件的开发模型如下图。

笺丑救渐桨致共焙傻怀券忻袒远疽臂秩别畦夸恐绞凉方蝉婆刮爱愉定墨穗软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第58页。基于构件的开发模型开发步骤

不考虑构件的开发技术,基于构件的开发模型由以下步骤组成:(1)对于该问题领域的基于构件的可用产品进行研究和评估。(2)考虑构件集成的问题。(3)设计软件架构以容纳这些构件。(4)将构件集成到架构中。(5)进行充分的测试以保证功能正常。道宽挡唆颜肖涯仗迟诽州课栗竹墙负右缉遗恶膏凄墅夹毋蚌缘盐睁婪桂灰软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第59页。基于构件的开发模型典型的构件模型(1)OMG/CORBA。对象管理组织发布了公共对象请求代理体系结构(OMG/CORBA),一个对象请求代理提供了多种服务,使得可复用构件(对象)可以与其他构件通信。(2)MicrosoftCOM/DCOM/.NET。微软公司开发了构件对象模型(COM),此模型提供了构件的规格说明,在Windows操作系统,一个应用系统中可以使用不同厂商生产的构件。(3)SunJavaBean构件。JavaBean构件系统是一个可移植的、平台独立的、使用Java程序设计语言开发的CBSE基础设施。皆督柴氢量夯炽兴鞘臭唤洁祟蝶昨嚷郡浆孝流淳沦衷婪锄孰纹弗肝雀疼桃软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第60页。统一过程由Booch、Jacobson及Rumbaugh提出,统一过程模型如图所示。

琐豫酷芍鞍淆宴坍栗窑猴驱谢钥啦赶腮预陕仪缉腺确杆嗡鸯梧候鉴供尉额软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第61页。统一过程统一过程的工作流

在统一过程中,有6个核心工作流。

①业务建模工作流。用商业用例为商业过程建立文档。②需求工作流。目标是描述系统应该做什么,确保开发人员构建正确的系统。为此,需明确系统的功能需求和非功能需求(约束)。③分析和设计工作流。其目标是说明如何做。结果是分析模型和设计模型。只旷厌摩彼捅猖咀惩弃酒网摔弯甸漱怔衫揖权珠尉炸芯妻凹痛抡铺胳蛛蘸软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第62页。统一过程④实现工作流。用分层的方式组织代码的结构,用构件的形式来实现类,对构件进行单元测试,将构件集成到可执行的系统中。⑤测试工作流。验证对象之间的交互、是否所有的构件都集成了、是否正确实现了所有需求、查错并改正。⑥部署工作流。制作软件的外部版本、软件打包、分发、为用户提供帮助和支持。襄邯劲丸蚁爸汕字骨低蚊逛猫吓错窗严牡砚终崭粮铬援泌圃商纳靡然估圣软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第63页。统一过程统一过程的阶段

统一过程有4个阶段,分别是初始阶段、细化阶段、构造阶段和移交阶段。①初始阶段。初始阶段主要关注项目计划和风险评估,其目的是确定是否值得开发目标信息系统。②细化阶段。细化阶段关心定义系统的总体框架,其目标是:细化初始需求(用况)、细化体系结构、监控风险并细化它们的优先级、细化业务案例以及制订项目管理计划。撅彤予嫌仑判政淖盾韵棺哪蜘徒尺钾桥用蛾轰绚肠寓奈挨蒂帘须搅缝巴码软件与软件工程介绍软件与软件工程介绍软件与软件工程介绍全文共72页,当前为第64页。统一过程统一过程的阶段③构造阶段。构造阶段是建立系统,构造信息系统的第1个具有操作质量的版本,以能够交付给客户进行测试的版本结束,有时称为测试版本。④移交阶段。移交阶段包含测试时期,以发布完整的系统而终止,其目标是确保信息系统真正满足客户的需

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论