翻新时间: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结构具有以下优点: 软件体系结构风格为大粒度的软件重用提供了可能。然而,对于应用体系结构风格来说,由于视点的不同,系统设计师有很大的选择空间。要为系统选择或设计某一个体系结构风格,必须根据特定项目的具体特点,进行分析比较后再确定。不同的结构有不同的处理能力的强项和弱点,一个系统的体系结构应该根据实际需要进行选择,以解决实际问题。
下载文档
网友最新关注
- 钓鱼
- 我最爱吃的菜
- 飞蛾扑“水”
- 探索的乐趣
- 做茶垫
- 考试后的感想
- 保护地球,爱我家园
- 我的家
- 我读过的书
- 第一次给鱼换水
- 感谢妈妈
- 请不要叫我“宝贝儿”
- 读书,真好!
- 脐橙
- 玩沙
- 教育就是培养习惯
- 校长个人工作总结
- 2009上半年物理教师个人工作小结
- 2009年教学工作总结
- 学校留守儿童教育管理工作总结
- 初中语文八年级教学工作总结
- 2009年教师教学工作总结
- 2009年初中教师个人工作总结
- 幼儿园中三班班级工作总结
- 2009年党员教师自评总结
- 2009年半年支教工作总结
- 2009年支教工作半年总结
- 优秀教师教学教育工作经验总结
- 中学远程教育资源应用教研工作总结
- 2009年教师党员工作小结
- 提高房屋土建工程施工质量的对策探讨
- 避免七误区 养猪效益增
- 浅谈规模化养猪场的消毒
- 养生丽水养猪行业生态循环建设①②
- 探究水利施工技术的发展
- 做强蛋鸡产业,发展规模养殖
- 规模化养猪场猪丹毒病的综合防治措施
- 当前农村养猪存在的问题及其对策
- 农大3号节粮小型蛋鸡配套系
- 兴宁市发展高效健康生态养猪的措施
- 新玉米饲喂蛋鸡应注意的事项
- 对于土建工程施工进度控制的探讨
- 对水库工程中的防渗漏处理的策略分析
- 水利施工中的风险抵押金规章
- 对土建工程施工质量控制的要点研究
- 读《草虫的村落》有感
- 《草虫的村落》学习目标
- 《山雨》教学反思
- 作文:《草虫的村落》
- 感悟体验 情感共鸣──《山雨》教学实录赏析
- 《草虫的村落》相关链接
- 《草虫的村落》教学建议
- 作文:《草虫的村落》
- 《草虫的村落》词句解析
- 《山雨》课堂实录及点评
- 让学生在读中感悟──《山雨》教学后记
- 《山雨》教学反思
- 作文:《草虫的村落》
- 作文:《草虫的村落》
- 《草虫的村落》课文简说