版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、软件体系结构Software Architecture教师:王凯东副教授,硕士导师(欢迎同学报考或报送研究生)Email:wkvaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.羽跨扰碴完验验畔墒咸汰衷挚拄泊昆稳栗罕揍羌铱赫形栓烽看麻羽辖帘陀软件体系结构第一章EX8cCore Material(教材及参考书)软件体系结构(第二版),张友生,北京:清华大学出版社,2006.软件体系结构原理、方法与实践,张友生,北
2、京:清华大学出版社,2009.Mary Shaw, David Garlan 著软件体系结构,北京 : 清华大学出版社,2007.Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.筷捌拒顾搂疑狠黄奈庚败收周叭酷蝗瓶胀破搐焰季饯梅排销昼溺词铃阮茶软件体系结构第一章EX8cCore Material(教材及参考书)Bass L, Clements P, Kazman R, Software Architecture in Practic
3、e, 2nd Edition, Addison Wesley, 2003.(软件构架实践,第二版,清华大学出版社)Shaw M, Garlan D, Software Architecture Perspectives on an emerging discipline, Prentice Hall, 1996.(软件体系结构一门初露端倪学科的展望,清华大学出版社)Stephen T.Albin, The Art of Software Architecture Design Methods and Techniques,2003. (软件体系结构的艺术,机械工业出版社)Eckel, B, T
4、hinking in Patterns, MindView, /Books/TIPatternsEvaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.纤寅隧勋景岛剂各店摇粤另谐精峙立苏鹏吩佩胚庆确陵敢穷枝疑哎迪洛饵软件体系结构第一章EX8c说明初步确定本课程的考核方法如下平时+作业 10%20%考试 90%80%TA 辅导时间 :每周五第5、6、7、8节课,在B603 605附近教师休息室。每周四下午5、6信远楼I-209教师休息室。E
5、valuation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.同晴欣拓弓路屋刚沃由腺槽太迎昆侯内参梳罪稀琼融事炎王彦懂阐扁纶烦软件体系结构第一章EX8c课 程 内 容 软件体系结构概论 软件体系结构建模 软件体系结构风格 软件体系结构描述 动态软件体系结构 Web服务体系结构 基于体系结构的软件开发 软件体系结构的分析与测试 软件体系结构评估 软件产品线体系结构Evaluation only.Created with Aspose.Slides
6、for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.臆彤清鸳恰孰案暴烈活济祖流泪苫涟信拯乙潍诉碱材淀怔壶济有生踢嫉澜软件体系结构第一章EX8c 产生背景 -软件的产生和发展的历史Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.葡棕沪各尾递舶抬馅外毙阉檬谨歇刑哈鹤老聂屠董阜廖馆逾洛骇裳叼徒侈软件体系结构第一章EX8c第一台计算机诞生机器指令编程(0和1组成)
7、Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.酷困原始瞅肘姐构梆什釜孜筒阵具渡寡斡涯谦渍荣现往或阳肾梁缩戒戈匀软件体系结构第一章EX8c回到过去!大众机械学杂志 1949将来的电脑将只有1000个电子管但是却有1.5吨重。我想在整个世界,我们只能卖出5台电脑。Thomas J. WatsonIBM董事会主席 1943没有必要每个人在家里都有一台电脑。Ken OlsonDEC总裁 1977Evaluation only.Creat
8、ed with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.桃骂这淋赫杠门童慢窍压锌参养瘪猿什痈傣自链颧添辖恫旱啡撬汰屯倚乔软件体系结构第一章EX8c计算机语言的产生1952年MIT开始使用汇编语言1954年IBM公司开发了Fortran语言1960年,计算机权威刊物CACM上发表了“关于算法语言Algol60的报告”1971,瑞士的Njklaus Wirth 在 Algol的基础上开始开发Pascal语言同年,美国的贝尔实验室的Dennis Ritche开发出 C 语言各种面向对象
9、的高级语言各种高级语言的诞生使得人们有可能编制出越来越复杂的软件系统Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.盛纸梦痹注糙慑裙逃务轻案鞘劈兑贴鹊棱淹嗅点拱军旋奈慰玩悬奏苔乍刻软件体系结构第一章EX8c软件危机软件的规模越来越庞大复杂度越来越高交付时间相对短产生软件危机Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyrigh
10、t 2004-2011 Aspose Pty Ltd.滑叭鉴蓝通挑榴于稍锣纹蛤浪谁午艇奸曳峙首灿沁傍漠血燎卿唆原膀够命软件体系结构第一章EX8c软件危机美国IBM公司在1963年至1966年开发的IBM360机的操作系统。这一项目花了5000人一年的工作量,最多时有1000人投入开发工作,写出了近100万行源程序。.据统计,这个操作系统每次发行的新版本都是从前一版本中找出1000个程序错误而修正的结果。.这个项目的负责人F. D. Brooks事后总结了他在组织开发过程中的沉痛教训时说:“.正像一只逃亡的野兽落到泥潭中做垂死的挣扎,越是挣扎,陷得越深,最后无法逃脱灭顶的灾难。.程序设计工作正像
11、这样一个泥潭,.一批批程序员被迫在泥潭中拼命挣扎,.谁也没有料到问题竟会陷入这样的困境.”。IBM360操作系统的历史教训成为软件开发项目的典型事例为人们所记取。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.睫凄踪煞音榷杏彝照嫁嚼仑除金卷疥槽济攫冻虏陪赐衬挥锗组伞伏恰检姚软件体系结构第一章EX8c软件危机软件危机的表现: 软件成本日益增长 开发进度难以控制 软件质量差 软件维护困难Evaluation only.Created
12、with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.彭恫肝川开府翔泌御骑余蟹挚放汞愚纪都减鹅鲤惑刃溉谬疵工夫傍铬诲逊软件体系结构第一章EX8c软件危机的主要表现Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.冈锌遣肌翔溃盔商磋庸惭阑唤荒撕尼挨搔梭丫霜俏券篓荤嫌炎枫翟奔峪叫软件体系结构第一章EX8c软件危机的主要表现 软
13、件成本日益增长20世纪50年代,软件成本在整个计算机系统成本中所占的比例为10%-20%。到20世纪60年代中期,软件成本在计算机系统中所占的比例已经增长到50%左右。 而且,该数字还在不断的递增,下面是一组来自美国空军计算机系统的数据:1955年,软件费用约占总费用的18%,1970年达到60%,1975年达到72%,1980年达到80%,1985年达到85%左右。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.哄奥恢戏兆躯征虱
14、汛橱命咽淫援言犁唯刽惮襄衷裙状系吁箩移盎幼昧奢磕软件体系结构第一章EX8c软件危机的主要表现开发进度难以控制在软件开发过程中,用户需求变化等各种意想不到的情况层出不穷,令软件开发过程很难保证按预定的计划实现,给项目计划和论证工作带来了很大的困难。盲目增加软件开发人员并不能成比例的提高软件开发能力。相反,随着人员数量的增加,人员的组织、协调、通信、培训和管理等方面的问题将更为严重。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.讹佛
15、髓走懒助咀凛躲葫冲用产罢伤忱抖窗兵默早貉璃跃叼儿克皇疹湘紊滁软件体系结构第一章EX8c软件危机的主要表现软件质量差 由于缺乏工程化思想的指导,程序员几乎总是习惯性的以自己的想法去代替用户对软件的需求,软件设计带有随意性,很多功能只是程序员的一厢情愿而已,这是造成软件令人不满意的重要因素。 软件项目即使能按预定日期完成,结果却不尽人意。1965年至1970年,美国范登堡基地发射火箭多次失败,绝大部分故障是由应用程序错误造成的。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004
16、-2011 Aspose Pty Ltd.痕袭潞确翻崩履浴扁陵寒这者复蛾疚式诡宏疡郭胃龙子蚤苔凹谁霜疙睬城软件体系结构第一章EX8c软件危机的主要表现软件维护困难由于在软件设计和开发过程中,没有严格遵循软件开发标准,各种随意性很大,没有完整的真实反映系统状况的记录文档,给软件维护造成了巨大的困难。特别是在软件使用过程中,原来的开发人员可能因各种原因已经离开原来的开发组织,使得软件几乎不可维护。有资料表明,工业界为维护软件支付的费用占全部硬件和软件费用的40-75%Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Pro
17、file .Copyright 2004-2011 Aspose Pty Ltd.斡石旦透抑爬酷狐宿寄步媚全侗疲酗伊敏活另碧肥吐妄讯登淬酵不疲罩损软件体系结构第一章EX8c人员构成: 微软产品组实例Windows 2000 Team开发人员900测试人员1800程序经理450文档人员100本地化人员110内部IT50市场人员100培训人员115技术支持人员 600技术传播人员 1120合计5345 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose
18、Pty Ltd.武盲改笋肝节触煞景嚼悠彤阿选呵油下摔愉鲜苹粉惧劲示书咐致卓安凄庆软件体系结构第一章EX8c软件危机软件危机的原因 ? 用户需求不明确 缺乏正确的理论指导 软件规模越来越大 软件复杂度越来越高Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.锐宴矩巨旷腺斧位暑钧为菏谰庇素芋膛把在搔铡靠帕扼擎佩价毙扰溅棚株软件体系结构第一章EX8c软件危机的原因 用户需求不明确 在软件开发完成之前,用户不清楚软件的具体需求; 用户对软件
19、需求的描述不精确,可能有遗漏、有二义性、甚至有错误; 在软件开发过程中,用户还提出修改软件功能、界面、支撑环境等方面的要求; 开发人员对用户需求的理解与用户本来愿望有差异。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.昨灶掣兢芳扮跳应栋助舶屁叫匝贺墨辟杰晾峡拘疲燃相没幽英惋卷秘今呜软件体系结构第一章EX8c软件危机的原因 缺乏正确的理论指导 缺乏有力的方法学和工具方面的支持。由于软件不同于大多数其他工业产品,其开发过程是复杂的
20、逻辑思维过程,其产品极大程度地依赖于开发人员高度的智力投入。由于过分地依靠程序设计人员在软件开发过程中的技巧和创造性,加剧软件产品的个性化,也是发生软件危机的一个重要原因。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.萧太枪阮扣钦纫楼潭饼谁工蚁慧页孜望逛青扯师案帘割缴椰嘘虞蔬公坐植软件体系结构第一章EX8c软件危机的原因 软件规模越来越大 随着软件应用范围的增广,软件规模愈来愈大。大型软件项目需要组织一定的人力共同完成,而多数
21、管理人员缺乏开发大型软件系统的经验,而多数软件开发人员又缺乏管理方面的经验。各类人员的信息交流不及时、不准确、有时还会产生误解。 软件项目开发人员不能有效地、独立自主地处理大型软件的全部关系和各个分支,因此容易产生疏漏和错误。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.骚修昏陇奠架谍肉核蝗简他操谗咙横稠让菊咆钻郑鹿倪灿岩淘谊狂轻艘缺软件体系结构第一章EX8c软件危机的原因 软件复杂度越来越高 软件不仅仅是在规模上快速地发展扩
22、大,而且其复杂性也急剧地增加。软件产品的特殊性和人类智力的局限性,导致人们无力处理“复杂问题”。 所谓“复杂问题”的概念是相对的,一旦人们采用先进的组织形式、开发方法和工具提高了软件开发效率和能力,新的、更大的、更复杂的问题又摆在人们的面前。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.跑啪糠姐遭料舆秒称姻靛仔疹淄竹铀闺蔑坛伙番取茨愉眷羌殊鳖伞菊桂挺软件体系结构第一章EX8c软件危机如何克服软件危机?Evaluation on
23、ly.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.旋邯愤掺矗蹋袋乐蘸蛋贺嫌无蜂彦橇吭脯搓赔弯份住踢庆赛套洗稿揭侣材软件体系结构第一章EX8cEvaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.撩芍谓炉褪猎喇畦盅担蹿呻牺耘隆姑熟汾经踊剿腹蹈笑吨弃梗侯宛嘘晶嚏软件体系结构第一章EX8cWhat is S
24、oftware Engineering?Software engineering is the activities and tasks that creates a software product. There are five main areas, these are:AnalysisDesignDevelopment (To most engineers, this is the most important)TestingMaintenanceEvaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile
25、 .Copyright 2004-2011 Aspose Pty Ltd.抚淤助款瑞诉磕氏夫隔梁弟琶友极院瓮抱敬吹锋脚截谅肪切秧践展沧搀难软件体系结构第一章EX8c软件工程(教材定义) 软件工程是用工程、科学和数学的原则与方法来研制、维护计算机软件的有关技术和管理方法。软件工程包括三个要素:软件工程方法软件工程工具软件工程的过程Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.涨憎阶谍巍提甄机找件那六丢但兑都鬼馒搜摆汾宛篡妆知捎蒲紫
26、作蔚粒迅软件体系结构第一章EX8c软件工程软件开发模型:瀑布模型演化模型螺旋模型增量模型喷泉模型智能模型Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.亚颅宦荷你婿俗言代郸盂弯样浙戊栋挝走厄于械瘪栓哑档聪雨径随悸乐抒软件体系结构第一章EX8c软件体系结构的产生和发展Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 20
27、04-2011 Aspose Pty Ltd.呸挡乾糠灿惯求扮吃朴诉积撮吧朴犯趴讥辙孝羊亮柒伸陶候碍绑警岔代艘软件体系结构第一章EX8c软件体系结构的产生和发展起初,人们把软件设计重点放在数据结构和算法上。随着软件系统规模越来越大、越来越复杂,整个系统的结构和规格说明显得越来越重要。 对于大规模的复杂软件系统来说,对总体的系统结构设计和规格说明比起对计算的算法和数据结构的选择已经变得明显重要的多。对软件体系结构的系统地、深入地研究将会成为提高软件生产率和解决软件维护问题的新的最有希望的途径。Evaluation only.Created with Aspose.Slides for .NET
28、3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.近岛泣猩陀添锅辽档獭豢骨簧岁恰贼扶爸颇瑰皖低链墒誊唆灌埂湾脂迹彦软件体系结构第一章EX8c软件体系结构的产生、兴起和发展事实上,软件总是有体系结构的,不存在没有体系结构的软件。软件体系结构虽脱胎于软件工程,但其形成同时借鉴了计算机体系结构和网络体系结构中很多宝贵的思想和方法,最近几年软件体系结构研究已完全独立于软件工程的研究,成为计算机科学的一个最新的研究方向和独立学科分支。Evaluation only.Created with Aspose.Slides for .NET 3.5
29、Client Profile .Copyright 2004-2011 Aspose Pty Ltd.阮煽则溢铸核烽砖戏阐迹裳省佯垃龄着奄瓶酿硒愿漓宣万涧煮镭冬述雹金软件体系结构第一章EX8cWhat is Software ArchitectureEvaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.朴麻漳耐痰放雌瞅敷秤厦潍案了授需千梭饯泵津炬刷瞄半坍皂膊瘟梧乍歇软件体系结构第一章EX8c对房子进行建模Evaluation only.
30、Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.可肖痰漠彦拂挨笼无硫余验把逮郝梁哺焦杆岔鹤疾犬跺躁曰声镐扦俺骋椅软件体系结构第一章EX8cWhat is Software Architecture 目前关于软件体系结构的定义有六十多种,有的定义从构造的角度来审视软件体系结构,有的侧重于从体系结构风格、模式和规则角度来考虑。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile
31、.Copyright 2004-2011 Aspose Pty Ltd.荐诣吮尉芹蔷据刁侥澄庐涩壁什馏替添鱼呵辩百耍锦菌盈忆屡卑荤台淖愉软件体系结构第一章EX8c软件体系结构的定义 Dewayne Perry和A1exander Wo1f 软件体系结构是具有一定形式的结构化元素,即构件的集合,包括处理构件、数据构件和连接构件。 处理构件负责对数据进行加工,数据构件是被加工的信息,连接构件把体系结构的不同部分组合连接起来。 这一定义注重区分处理构件、数据构件和连接构件,这一方法在其他的定义和方法中基本上得到保持。 Evaluation only.Created with Aspose.Slide
32、s for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.择日紊区娇埋邻袭恒换剥豢襄烈他股厅次浑匪器楷圆踢种徐毁索苹危哀鼓软件体系结构第一章EX8c软件体系结构的定义 Mary Shaw和David Garlan 软件体系结构是软件设计过程中的一个层次,这一层次超越计算过程中的算法设计和数据结构设计。 体系结构问题包括总体组织和全局控制、通讯协议、同步、数据存取,给设计元素分配特定功能,设计元素的组织,规模和性能,在各设计方案间进行选择等。 软件体系结构处理算法与数据结构之上关于整体系统结构设计和描述方面的一些问题,如全
33、局组织和全局控制结构、关于通讯、同步与数据存取的协议,设计构件功能定义,物理分布与合成,设计方案的选择、评估与实现等。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.长低眉彝酿酞劝蕾拌偏凳但怀浴鞍挛塔斌备多塘皇淤记颖胺默罐樱方筐谅软件体系结构第一章EX8c软件体系结构的定义 Kruchten 软件体系结构有四个角度,它们从不同方面对系统进行描述:概念角度描述系统的主要构件及它们之间的关系;模块角度包含功能分解与层次结构;运行角度描
34、述了一个系统的动态结构;代码角度描述了各种代码和库函数在开发环境中的组织。 Hayes Roth 软件体系结构是一个抽象的系统规范,主要包括用其行为来描述的功能构件和构件之间的相互连接、接口和关系。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.糠累狄盆囚快躲灌有答档衷文祝豺或憎避丰郝晒邵蜕貌涎荔拓副或溢乓体软件体系结构第一章EX8c软件体系结构的定义 David Garlan 和 Dewne Perry 软件体系结构是一个程序
35、系统各构件的结构、它们之间的相互关系以及进行设计的原则和随时间演化的指导方针。 Barry Boehm 软件体系结构包括一个软件和系统构件,互联及约束的集合;一个系统需求说明的集合;一个基本原理用以说明这一构件,互联和约束能够满足系统需求。 ?Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.且远守拇归阁屏欣屿乖寥到舔窘岩歇砌背藕懦暗甥纠萨毖益化槐抠年钩俱软件体系结构第一章EX8c软件体系结构的定义 Bass,Ctements 和
36、Kazman 软件体系结构包括一个或一组软件构件、软件构件的外部的可见特性及其相互关系。其中,“软件外部的可见特性”是指软件构件提供的服务、性能、特性、错误处理、共享资源使用等。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.宅嫁价雄氦哦喜彰荷壕狮衅绅续顽猪养案苞热谈赂去来石捻咋豺槛疤畜乙软件体系结构第一章EX8c软件体系结构的定义 我们的定义 软件体系结构为软件系统提供了一个结构、行为和属性的高级抽象,由构成系统的元素的描述、
37、这些元素的相互作用、指导元素集成的模式以及这些模式的约束组成。 软件体系结构不仅指定了系统的组织结构和拓扑结构,并且显示了系统需求和构成系统的元素之间的对应关系,提供了一些设计决策的基本原理。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.冲筐夺揪叙惹日县临贺汞与盈诈辕蕊岿孵收秉铣癌螺圭凳按然击奄症凸枯软件体系结构第一章EX8c软件体系结构的意义 体系结构是风险承担者进行交流的手段 软件体系结构代表了系统的公共的高层次的抽象。这样
38、,系统的大部分有关人员(即使不是全部)能把它作为建立一个互相理解的基础,形成统一认识,互相交流。 体系结构提供了一种共同语言来表达各种关注和协商,进而对大型复杂系统能进行理智的管理。这对项目最终的质量和使用有极大的影响。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.归编眶蒸萍希店蕉猿瘴蹬俯筛宝洽褂新裔戎竟沫煽煤夕烘丛荐酿迄杯羊徽软件体系结构第一章EX8c软件体系结构的意义 体系结构是早期设计决策的体现 (1)软件体系结构明确了
39、对系统实现的约束条件(2)软件体系结构决定了开发和维护组织的组织结构(3)软件体系结构制约着系统的质量属性(4)通过研究软件体系结构可能预测软件的质量(5)软件体系结构使推理和控制更改更简单(6)软件体系结构有助于循序渐进的原型设计(7)软件体系结构可以作为培训的基础Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.补鸽辙攘砚住熙敲慢橡俞铬选掂哦垒穴憾猖蒂甸疼招侈竭蜀菜拭笨征镍汹软件体系结构第一章EX8c软件体系结构的意义 软件体系
40、结构是可传递和可重用的模型 软件体系结构级的重用意味着体系结构的决策能在具有相似需求的多个系统中发生影响,这比代码级的重用要有更大的好处。 通过体系结构的抽象可以使设计者能够对一些经过实践证明是非常有效的体系结构构件进行重用,从而提高设计效率和可靠性,大大降低设计的复杂性。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.焕哆擅嘉页态重至酝津普婆栗峰泊吵知截缴秉讲最陀浪矩哎曲蹭侮哄敦凛软件体系结构第一章EX8c软件体系结构的发展史
41、 Perry和Wolf认为未来的年代是研究软件体系结构的时代 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.匆厄鼓拔撩哪柒鼠苗刻袱恰曹言方翔温纬坑更且嵌拎掸得股更哩寨汹铺籍软件体系结构第一章EX8c软件体系结构的应用现状 软件体系结构描述语言 体系结构描述构造与表示 体系结构分析、设计与验证 体系结构发现、演化与重用 基于体系结构的软件开发方法 特定领域的体系结构框架 软件体系结构支持工具 软件产品线体系结构 建立评价软件体系结
42、构的方法Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.畦却仗柠徘余撩颇苗漓趁抨脏憾拓垃杆枢铲颠液屿宠烧巧惦毙渤葛还坊国软件体系结构第一章EX8c构件与软件重用 构件模型及实现 软件重用是指两次或多次不同软件开发过程中重复使用相同或相近软件元素的过程。软件元素包括程序代码、测试用例、设计文档、设计过程、需求分析文档和领域分析知识。 把可重用的软件元素称为软件构件,简称构件。可重用的软件元素越大,重用的颗粒度越大。 构件的定义 构件
43、是指语义完整、语法正确和有可重用价值的单位软件,是软件重用过程中可以明确辨识的系统;结构上,它是语义描述、通讯接口和实现代码的复合体。构件的使用同它的开发、生产无关。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.卒慢条皆如枕苗睡便山论充刻麓鼠秘兵欣歼厌醋坊乒烫懂雇渗寐随歉连渝软件体系结构第一章EX8c构件与软件重用 构件模型及实现 参考模型,描述模型,实现模型 构件模型的三个主要流派 OMG(Object Management
44、Group,对象管理集团)的CORBA(Common Object Request Broker Architecture,通用对象请求代理结构) Sun的EJB(Enterprise Java Bean) Microsoft的DCOM(Distributed Component Object Model,分布式构件对象模型)。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.涣险章崖饮敷岭冬巍惭伞知撂手操糊怂暗茂烹惑揉挖贼峭萌材
45、澈窟刺袒缓软件体系结构第一章EX8c构件与软件重用构件获取 (重用) 领域具有内聚性和稳定性特征,具有可重用性。 从现有构件中获得符合要求的构件,直接使用或作适应性修改,得到可重用的构件; 通过遗留工程,将具有潜在重用价值的构件提取出来,得到可重用的构件; 从市场上购买现成的商业构件,即COTS(Commercial Off-The-Shell)构件; 开发新的符合要求的构件。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.痰服哮
46、少霉戈炕匡畦仲愁战炬许抱尝橇盅丽崔氧针督荧换赠尖遏惑丧达魄软件体系结构第一章EX8c构件与软件重用构件管理 构件描述 构件分类与组织 人员及权限管理Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.冻伐捡垒示纬迎郸唁蔫动挑锭褂户毗接塞答仙液积渣隘妥菲检海媒腋审咀软件体系结构第一章EX8c构件与软件重用构件管理 构件描述 构件模型是对构件本质的抽象描述,主要是为构件的制作与构件的重用提供依据; 从管理角度出发,也需要对构件进行描述,例
47、如:实现方式、实现体、注释、生产者、生产日期、大小、价格、版本和关联构件等信息,它们与构件模型共同组成了对构件的完整描述。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.伍牙谋铡诈郁忆殖钵香爷嗽回庙忠晓糟腐掂芍刹露悦堕洁氛侈腾辰缠爽逼软件体系结构第一章EX8c构件与软件重用构件管理 构件分类与组织 关键字分类法 刻面分类法 超文本组织方法 Evaluation only.Created with Aspose.Slides for
48、 .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.霍庄捻才炼册颂肾零媒椒愿鬃差茹倚锭闸俊貉琼瘩牵咱石谬慑拨租遏胃五软件体系结构第一章EX8c构件与软件重用 关键字分类法Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.菊袍炮纳聋桃处庶耸短阁胰绑鞭涯瘟迸盲媒偿骚培庇征吵妇辰奈双绒岂千软件体系结构第一章EX8c构件与软件重用 刻面分类法 思想来源于图书馆学举例: 使
49、用环境 应用领域 功能 层次 表示方法Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.嘎娩欺门将旬讲刻宅禽端哄尧侥耸麻猛锣驳舅填贮媚笛贪烫机隅崇以华迢软件体系结构第一章EX8c构件与软件重用 超文本组织方法 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.搔黍啼冷维樟
50、眉合翌恃廷靡卿墙眷囤处饺袒玄巍睡霸弘寐怂脸粉骗箕旦晋软件体系结构第一章EX8c构件与软件重用构件管理 人员及权限管理 一般来讲,构件库系统可包括五类用户,即注册用户、公共用户、构件提交者、一般系统管理员和超级系统管理员。 不同的职责,不同的权限,互相协作,共同维护构件库正常运作。 Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.志股逐县边武剂模码孝典恩毅抑阻疫淑枫硷修屁狸撂即筛爬焕卸犊乒状堑软件体系结构第一章EX8c构件与软件重用
51、构件重用 检索与提取构件 理解与评价构件 修改构件 构件组装Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.歇仓奠疼职隶慌们枯真阂靠拯讫赫柿么卓挎岔坯精娱砧旬依厚只替杀哄厩软件体系结构第一章EX8c构件与软件重用构件重用 检索与提取构件 基于关键字的检索 刻面检索法 超文本检索法 其他检索方法Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile
52、 .Copyright 2004-2011 Aspose Pty Ltd.锚譬喇稗乾嘎逗怜彪惮死曹衡赊呆旗弃汝革锯创萎少词晃堤嵌贪兵唁拿柒软件体系结构第一章EX8c构件与软件重用构件重用 理解与评价构件 构件的功能与行为 相关的领域知识 可适应性约束条件与例外情形 可以预见的修改部分及修改方法Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.魄洗蔬沾了滋区综撇沮酮缚故突踪风师欠绪宪砒杯苟仟植道谤痔诽值赞鸽软件体系结构第一章EX8c构件与软件重用构件重用 修改构件 理想的情形是对库中的构件不作修改而直接用于新的软件项目。 但是,在大多数情况下,必须对构件进行或多或少的修改,以适应新的需求。 为了减少构件修改的工作量,要求开发人员尽量使构件的功能、行为和接口设计更为抽象化、通用化和参数化。Evaluation only.Created with Aspose.Slides for .NET 3.5 Client Profile .Copyright 2004-2011 Aspose Pty Ltd.环蜒芥艳
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- Porfimer-sodium-Photofrin-II-生命科学试剂-MCE
- plus-Nipecotic-acid-plus-β-Homoproline-生命科学试剂-MCE
- 全国粤教版信息技术八年级下册第二单元第十一课《数字信号与模拟信号》教学实录
- 辽宁2024年辽宁省公共文化服务中心招聘38人历年参考题库(频考版)含答案解析
- 第12课《醉翁亭记》教学实录- 2024-2025学年统编版语文九年级上册
- 第七章第三节 印度教学实录2023-2024学年人教版七年级地理下册
- 2024年五年级英语上册 Module 1 Unit 1 Did you come back yesterday教学实录 外研版(三起)
- 沪科版(2023)信息技术九上 第三单元 活动二《枚举商品搭配方法》教学实录
- 泰山科技学院《数据库原理A》2023-2024学年第一学期期末试卷
- 珠海广东珠海市卫生健康局面向2025年应届生招聘所属公立医院工作人员69人历年参考题库(频考版)含答案解析
- JJF 1585-2016固定污染源烟气排放连续监测系统校准规范
- 首都博物馆参观汇报参考课件
- 《中级微观经济学》考试复习题库(附答案)
- 国家开放大学《美学原理》形考作业1-5参考答案
- 混凝土强度检验评定记录
- 《生于华夏何其有幸》演讲稿
- 水文地质学基础:第十一章 裂隙水
- 气道廓清技术及护理课件
- 总包向防火门单位移交防火门安装工作面交接单
- A、D式离心风机使用说明书
- 小学数学人教版一年级下第六单元教材分析(2)
评论
0/150
提交评论