翻新时间:2023-08-05
几种软件体系结构风格阐述
几种软件体系结构风格阐述 几种软件体系结构风格阐述 几种软件体系结构风格阐述
20世纪60年代中期的软件危机使得人们开始重视软件工程的研究。起初,人们把软件设计的重点放在数据结构和算法的选择上。随着软件系统规模越来越大、越来越复杂,整个系统的结构显得越来越重要。
一、软件体系结构风格分析
最初的软件体系结构是Mainframe结构——客户、数据和程序都被集中在主机上,通常只有少量的GUI界面,对远程数据库的访问比较困难。随着PC的广泛应用,该结构逐渐被淘汰。在20世纪80年代中期出现了Client/Server分布式计算结构,应用程序的处理在客户机和服务器之间分担。随着大型软件系统的开发,这种结构在系统的部署和扩展性方面暴漏出不足。随着Internet的发展,一个更灵活的体系结构“三层/多层计算”体系结构应运而生。
Garlan和Shaw将通用软件体系结构风格总结为以下几类: 下面将介绍几种主要和经典的体系结构风格和它们的优缺点。 C2风格是最常用的一种软件体系结构风格。从C2风格的组织规则和结构图中,我们可以得出,C2风格具有以下特点: 2.数据抽象和面向对象风格。目前软件界已普遍转向使用面向对象系统,抽象数据类型概念对软件系统有着重要作用。这种风格的构件是对象,或者说是抽象数据类型的实例。对象是一种被称作管理者的构件,因为它负责保持资源的完整性。对象是通过函数和过程的调用来交互的。图2是数据抽象和面向对象风格的示意图。
面向对象的系统有许多的优点: 3.基于事件的隐式调用风格。基于事件的隐式调用风格的思想是构件不直接调用一个过程,而是触发或广播一个或多个事件。系统中的其他构件中的过程在一个或多个事件中注册,当一个事件被触发,系统自动调用在这个事件中注册的所有过程,这样,一个事件的触发就导致了另一模块中的过程的调用。基于事件的隐式调用风格的主要特点是事件的触发者并不知道哪些构件会被这些事件影响。这样不能假定构件的处理顺序,甚至不知道哪些过程会被调用。隐式调用系统的主要优点有:
(1)为软件重用提供了强大的支持。当需要将一个构件加入现存系统中时,只需将它注册到系统的事件中。
(2)为改进系统带来了方便。当用一个构件代替另一个构件时,不会影响到其他构件的接口。隐式调用系统的主要缺点有:①构件放弃了对系统计算的控制。一个构件触发一个事件时,不能确定其他构件是否会响应它。而且即使它知道事件注册了哪些构件的构成,它也不能保证这些过程被 调用的顺序。②数据交换的问题。有时数据可被一个事件传递,但另一些情况下,基于事件的系统必须依靠一个共享的仓库进行交互。在这些情况下,全局性能和资源管理便成了问题。③既然过程的语义必须依赖于被触发事件的上下文约束,关于正确性的推理存在问题。 4.管道/过滤器风格。在管道/过滤器风格的软件体系结构中,每个构件都有一组输入和输出,构件读输入的数据流,经过内部处理,然后产生输出数据流。这个过程通常通过对输入流的变换及增量计算来完成,所以在输入被完全消费之前,输出便产生了。因此,这里的构件被称为过滤器,这种风格的连接件就象是数据流传输的管道,将一个过滤器的输出传到另一过滤器的输入。
图3是管道/过滤器风格的示意图。
管道/过滤器风格的软件体系结构的优点: 5.批处理风格。批处理风格的每一步处理都是独立的,并且每一步是顺序执行的,只有当前一步处理完后,后一步处理才能开始,数据传送在步与步之间作为一个整体。批处理的典型应用是经典数据处理和程序开发。
批处理风格与管道过滤器风格的共同点是把任务分解成一系列固定顺序的计算单元(组件),组件间只通过数据传递交互。区别表现在以下几个方面:批处理是全部的、高潜伏性的、输入时可随机存取、无合作性、无交互性,管道过、滤器是递增的、数据结果延迟小、输入时处理局部化、有反馈、可交互。
6.仓库风格。在仓库风格中,有两种不同的构件:中央数据结构说明当前状态,独立构件在中央数据存贮上执行,仓库与外构件间的相互作用在系统中会有大的变化。
若输入流中某类时间触发进程执行的选择,则仓库是一传统型数据库;另一方面,若中央数据结构的当前状态触发进程执行的选择,则仓库是一黑板系统。
二、三层C/S软件体系结构分析
C/S软件体系结构是20世纪90年代成熟起来的技术,它将应用一分为二,服务器(后台)负责数据管理,客户机(前台)完成与用户的交互任务。 表示层是应用的用户接口部分,它担负着用户与应用间的对话功能。表示层一般使用图形用户接口,操作简单、易学易用。功能层相当于应用的本体,它是将具体的业务处理逻辑编入程序中。功能层的程序多半是用可视化编程工具开发的。数据层就是数据库管理系统,负责管理对数据库数据的读写。数据库管理系统必须能迅速执行大量数据的更新和检索。因此,一般从功能层传送到数据层的要求大都使用SQL语言。
对二层C/S结构的局限,三层C/S的解决方案是:对这三层进行明确分割,并在逻辑上使其独立。与传统的二层结构相比,三层C/S结构具有以下优点: 软件体系结构风格为大粒度的软件重用提供了可能。然而,对于应用体系结构风格来说,由于视点的不同,系统设计师有很大的选择空间。要为系统选择或设计某一个体系结构风格,必须根据特定项目的具体特点,进行分析比较后再确定。不同的结构有不同的处理能力的强项和弱点,一个系统的体系结构应该根据实际需要进行选择,以解决实际问题。
下载文档
网友最新关注
- 我最喜欢的玩具
- 捉蚂蚱
- 我的课余生活
- 选闪亮女生
- 暑假麻辣烫
- 可爱的小乌龟
- 试卷发下来以后
- 钓龙虾
- 学溜冰
- 一次钢琴比赛
- 2008北京奥运会的冠军
- 快乐的元旦
- 母爱
- 大树的自述
- 王老师的妙计
- 集团先进性教育工作总结
- 2006上半年教育技术室工作总结
- 体育教学部先进性教育“回头看”工作总结
- 宜昌市第七中学女职工委员会2006年工作总结
- 2006年上半年建邺区电教工作总结
- 林大附小巩固和扩大整改成果“回头看”工作总结
- 2006年教师个人工作总结(小学类)
- 新疆财经学院对口支援工作总结
- 玄武区电教中心2006年上半年工作总结
- 2006-2007学年现代教育技术组工作计划
- 生物学院党员先进性教育“回头看”工作总结
- 2006--2007学年七年级工作计划
- 2006-2007学年第一学期秦淮区电教中心工作计划
- 2006秋学期036班工作总结
- 信息学院党总支“回头看”工作总结
- 试析朱自清散文中的尚清审美倾向
- 试析《静静的顿河》中“家的时空体
- 试析中世纪文学批评的几种主要模式
- 分析曹文轩小说创作中的传统美学元素
- 试论跨文化传播对现代大学生文化意识的影响
- 试析高职艺术教育发展的问题剖析与对策
- 浅析毛泽东民主集中制思想对领导班子建设的意义
- 简论显性教育与隐性教育整合的对策探析
- 被缚的孙悟空
- 在个体与公共之间追寻
- 关于专业批评家与网络文学批评
- 简论构建科学健康的博客文化
- 试析案例教学法在民法教学中的应用
- 浅析高校人力资源管理的法律风险控制体系构建
- 简论如何提高学生的写作能力
- 《草原》第二课时教学实录及点评
- 《丝绸之路》读后感──“让书香美丽心灵”读书笔记
- 学美文,做“美人”──教学《草原》一得
- 《草原》教学案例及反思
- 张骞与丝绸之路
- 《草原》课堂教学实录片断
- 《丝绸之路》课文题解
- 《草原》教学案例
- 《丝绸之路》相关链接
- 《草原》教学实录及评析
- 导入技能及其在《草原》一课教学中的运用
- 让美永驻我们的心田──《草原》教学案例及反思
- 《草原》教学感悟与反思
- 《草原》教学实录及评析
- 凭借教材训练学生的表达能力──《草原》教学反思