高级软件架构设计课件.ppt
《高级软件架构设计课件.ppt》由会员分享,可在线阅读,更多相关《高级软件架构设计课件.ppt(235页珍藏版)》请在三一办公上搜索。
1、.,1,高级软件架构设计,康凯Msn: Mail: ,.,2,目录,第一单元:软件生命周期与软件架构介绍2第二单元:技术架构视图面向对象程序设计原则与模式 24用GRASP模式指导设计27领域模型47面向对象设计的基本原则71第三单元:用UML辅助系统分析与设计103UML简介及常见疑难问题辨析104借鉴RUP的UML建模与分析117第四单元:设计模式与软件设计思想131设计模式132常用的软件架构风格及适用情况分析172SOA 及分层架构设计212第五单元:架构设计实践225,.,3,第一单元:软件生命周期与软件架构介绍,.,4,IT行业的人才结构与软件架构师的定位软件架构师应掌握的知识体系
2、软件架构设计的特点、层次、分类软件架构的主要理论、方向和趋势软件工厂,实现软件开发的产业化,.,5,软件架构师的定位,系统架构师的职责:一、理解系统的业务需求,制定系统的整体框架(包括:技术框架和业务框架)二、对系统框架相关技术和业务进行培训,指导开发人员开发。并解决系统开发、运行中出现的各种问题。系统架构师的目的:对系统的重用、扩展、安全、性能、伸缩性、简洁等做系统级的把握。系统架构师能力要求:一、系统架构相关的知识和经验。二、很强的自学能力、分析能力、解决问题的能力。三、写作、沟通表达、培训。,.,6,角色软件架构师Software Architect定义主导系统全局分析设计和实施、负责软
3、件构架和关键技术决策的角色,.,7,职责领导与协调整个项目中的技术活动(分析、设计和实施等)推动主要的技术决策,并最终表达为软件构架确定和文档化系统的相对构架而言意义重大的方面,包括系统的需求、设计、实施和部署等“视图”确定设计元素的分组以及这些主要分组之间的接口为技术决策提供规则,平衡各类涉众的不同关注点,化解技术风险,并保证相关决定被有效的传达和贯彻理解、评价并接收系统需求评价和确认软件架构的实现,.,8,专业技能技术全面、成熟练达、洞察力强、经验丰富,具备在缺乏完整信息、众多问题交织一团、模糊和矛盾的情况下,迅速抓住问题要害,并做出合理的关键决定的能力。具备战略性和前瞻性思维能力,善于把
4、握全局,能够在更高抽象级别上进行思考。对项目开发涉及的所有问题领域都有经验,包括彻底地理解项目需求,开展分析设计之类软件工程活动等。具备领导素质,以在各小组之间推进技术工作,并在项目压力下做出牢靠的关键决策。拥有优秀的沟通能力,用以进行说服、鼓励和指导等活动,并赢得项目成员的信任。,.,9,以目标导向和主动的方式来不带任何感情色彩地关注项目结果,构架师应当是项目背后的技术推动力,而非构想者或梦想家(追求完美)精通构架设计的理论、实践和工具,并掌握多种参考构架、主要的可重用构架机制和模式。具备系统设计员的所有技能,但涉及面更广、抽象级别更高。,.,10,软件架构师的知识体系,软件架构师作为整个软
5、件系统结构的总设计师,其知识体系、技能和经验决定了软件系统的可靠性、安全性、可维护性、可扩展性和可移植性等方面的性能。因此一个优秀的软件架构师必须具备相当丰富的知识、技能和经验。通过对比软件架构师和系统分析师在软件开发中的职责和角色,不难发现软件架构师与系统分析师所必需的知识体系也是不尽相同的,系统分析师的主要职责是在需求分析、开发管理、运行维护等方面,而软件架构师的重点工作是在架构与设计这两个关键环节上。因此在系统分析师必须具备的知识体系中对系统的构架与设计等方面知识体系的要求就相对低些;而软件架构师在需求分析、项目管理、运行维护等方面知识的要求也就相对低些。,.,11,成为一名合格的软件架
6、构师必须具备的知识信息系统综合知识体系软件架构知识体系,.,12,?,MFC,MSF,MOF,RUP,J2EE,Spring,SOA,JUnit,ORM,.NetMVC,UML,XML,Corba,MDA,MDD,Web-ServiceRSS,Web2.0,AJAX,Serverlet,HibernateIOC, AOPRuby On RailsRupBPELWorkflow EngineLBSOracleCMMIMQ,.,13,软件架构师在干什么?,思考、思考、再思考深入理解、准确把握建设的业务需求分析所有可见的问题、障碍、风险充分参考已有的成功方案,降低风险交流、讨论、博弈、质疑对构思中的
7、方案不断提出质疑,避免漏洞广泛听取各层面的意见,开拓思路反复质疑、逐步完善已有的设计构思在动手实现之前验证设计方案的正确性,.,14,软件架构师的知识结构,软件知识最好要有系统开发全过程经验。对 IT 建设生命周期各个环节有深入了解,包括:系统/模块逻辑设计、物理设计、代码开发、项目管理、测试、发布、运行维护等。深入掌握1-2种主流技术平台上开发系统的方法。了解多种应用系统的结构。了解架构设计领域的主要理论、流派、框架。,.,15,软件架构师的知识结构,业务知识深入了解系统建设的业务需求。了解系统的非功能需求和运行维护需求。了解企业 IT 公共设施、网络环境、外部系统。,.,16,软件架构师的
8、思维方式,基于框架的思维架构设计的层次(Enterprise, Application, etc)IT 的生命周期(What, Why, Where, How, When, etc)成功经验以及方法论的指导合理把握技术细节把握各个层次应有的内容合理忽略不应有的技术细节,.,17,软件架构师的思维方式,风险管理意识采用成功经验、避免不应有的风险多方位的开放思维多维度、多方向、包容性、避免排他性分析、质疑、抽象、归纳没有绝对好的架构设计,只有相对优秀的方案,.,18,信息系统综合知识体系,(1)计算机系统综合知识:包括计算机组成与体系结构、嵌入式系统和操作系统等方面的知识。(2)系统配置和方法:包
9、括系统配置技术和系统性能等方面的知识。(3)典型系统应用:包括网络应用、数据库应用和多媒体系统等方面的知识。(4)系统开发:包括程序设计语言、软件开发方法、需求分析和设计方法、测试评审方法、开发管理、应用系统构建、系统审计、外部资源使用和基于中间件的开发等方面的知识。(5)安全性和可靠性技术:包括数据安全与保密、防闯入和防病毒、容错技术、可靠性模型与分析技术、系统可靠性、安全规章和保护私有信息规则等方面的知识。,.,19,(6)标准化:包括标准化的基础知识、标准化分级、编码标准、数据交换标准、软件工程标准、信息安全标准、基于构件的软件标准和标准化组织机构等方面的知识。(7)信息化基础:包括政府
10、信息化与电子政务、企业信息化与电子商务、信息化的有关的法律和规定等方面的知识。(8)数学和英语:至少具有大学以上的数学和英语基础知识。,.,20,软件架构知识体系,(1)系统计划:包括项目的提出和可行性分析、系统方案的制定、评价和改进、新旧系统的分析与比较、现有软、硬件和数据资源的有效利用等。(2)软件架构设计:包括软件架构的概念、软件架构与设计、架构风格、特定领域的架构风格、基于架构的软件开发方法、架构评估、软件产品线和系统演化等。(3)设计模式:包括设计模式的概念、组成、分类和实现、模式和软件架构的关系等。(4)系统设计:包括处理流程设计、人机界面设计、文件与存储设计、数据库设计、网络应用
11、系统的设计、系统运行环境的集成与设计、中间件与应用服务器、性能设计与性能评估等。(5)软件建模:包括定义问题与归结模型、结构化系统建模与数据流图、面向对象系统建模、数据库建模和逆向工程等。,.,21,(6)分布式系统设计:包括分布式通信协议的设计、基于对象与web的分布式设计、基于消息和协同的分布式设计和异构分布式系统的互操作性设计等。(7)嵌入式系统设计:包括实施任务调度和多任务设计、中断处理和异常处理、嵌入式系统开发设计等。(8)系统可靠性分析与设计:包括系统故障模型和可靠性模型、系统的可靠性分析与可靠度计算、提高系统可靠性的措施、系统的故障对策和系统的备份与恢复等。(9)系统的安全性和保
12、密性设计:包括系统的访问控制技术、数据的完整性、数据与文件的加密、通信的安全和系统的安全设计等。(10)复杂架构设计:包括操作系统的架构、编译器的架构和大型基础库的架构等。,.,22,软件架构师的任职条件,根据软件架构师的职责和角色定位,以及知识体系,从实践的角度考虑,合格的软件架构师应该具有以下能力和经验:(1)具有8年以上的软件项目开发实际工作经验,其中至少有3年以上的代码编写工作经验,4年以上的基于面向对象和构件开发方法的软件产品设计经验。 (2)具有5个以上大中型开发项目的总体规划、方案设计经验,有大中型应用系统开发和实施的成功案例。(3)对相关的技术标准有深刻的认识,对软件工程标准和
13、规范有良好的把握。 (4)对.Net或Java技术及整个解决方案有深刻的理解及熟练的应用,精通Web Service,熟练掌握流行的架构。,.,23,(5)对设计模式有深刻的理解,并能在此基础上设计出适合产品特性和质量属性的框架。(6)具有面向对象的分析、设计和开发能力,精通UML和XML,能熟练使用Rational Rose、PowerDesigner等工具进行设计。 (7)具有良好的团队意识和协作精神,有较强的沟通能力和书面表达能力。(8)具有旺盛的精力和学习能力,能快速掌握新技术和新方法。,.,24,第二单元:技术架构视图面向对象程序设计原则与模式,.,25,.,26,.,27,用GRA
14、SP模式指导设计,.,28,.,29,.,30,.,31,.,32,.,33,.,34,.,35,.,36,.,37,.,38,.,39,.,40,.,41,.,42,.,43,.,44,.,45,.,46,.,47,领域模型,.,48,层次结构领域模型从EJB到轻量级框架,.,49,层次结构,表现层(present)业务层业务层外观业务层核心领域对象管理/服务/仓库层领域对象层持久层数据访问层数据库,.,50,领域模型中的各种角色:实体-有唯一的标识,并且要有属性和行为(非GET/SET),添加了行为,使其具有生命力。往往在设计时,实体的形为最难决断。为确定行为,我们必须识别它们的责任和协作
15、。类的责任是指该类要做、知道、或决定的一切,由一个或多个方法完成。类中有属性和关联,协作就是为完成自己的责任所调用其它关联类。值对象-没有标识没有行为。如Address类。工厂-定义创建实体的方法,封装实例化对象并将一些关联对象注入。仓库(repository)管理实体的集合,主要有查找和删除实体的方法.实现类可以调用执久化层(如Hibernate,Ibatis)服务(Service) ,实现整个应用程序的工作流(workflow)。服务包含那些无法指派的单个实体的行为,由作用于多个对象方法组成。如可以调用repository查找到实体对象,然后委派给这些对象。服务和facade很像,但不一样
16、,它不处理以下事情:1)执行事务。2)收集返回给表现层的数据。3)脱钩对象。4)其它事情。服务可以说是业务的协调者,业务逻辑可以分散到实体对象中。,.,51,领域模型,失血模型贫血模型充血模型胀血模型,.,52,失血模型,DO只有属性及其getter/setter方法,没有任何业务逻辑。缺点:行为与数据分离,很多情况导致维护与理解困难。,.,53,贫血模型,DO包含不依赖于持久化的领域逻辑;依赖持久化的领域逻辑归入Service层。Service(业务逻辑,事务封装) DAODO优点:各层单向依赖,结构清楚,易于实现和维护。设计简单易行,底层模型非常稳定。缺点:DO部分的持久化逻辑被放入Ser
17、vice层,不够OO。Service层过重。,.,54,充血模型,与贫血模型类似,不同处在于如何划分业务逻辑:绝大多业务逻辑都应该放在DO里(包括持久化逻辑),而Service层很薄,仅仅封装事务和少量逻辑,不和DAO层打交道。Service(事务封装)DO DAO优点:符合OOService层很薄,只充当Facade的角色,不和DAO打交道。,.,55,缺点:DAO和DO双向依赖。如何划分Service层逻辑和Domain层逻辑没有确定的规则,取决与设计人员自己的理解。Service层封装事务,须对所有的DO逻辑提供相应的事务封装方法,造成重定义所有的Domain logic。Service
18、的事务化封装的意义等于把OO的Domain logic转换为过程的Service 事务脚本。充血模型在domain层实现的OO在Service层又变成了面向过程。,.,56,胀血模型,取消Service层,只剩下DO和DAO层,在DO的domain logic上面封装事务。DO(事务封装,业务逻辑)DAO(RoR甚至合并为一层) 优点:分层简化符合OO缺点:service逻辑也强行放入DO ,引起了DO不稳定。DO暴露给web层过多的信息,可能引起不必要的耦合。,.,57,原则:业务对象封装了内在的业务逻辑,而应用服务封装了外在于业务对象的业务逻辑。,.,58,EJB到轻量级框架,EJBPOJ
19、O (业务逻辑) + 轻量级框架(Hibernate、JDO、iBATIS(持久化)、Spring(事务管理、安全),.,59,EJB,EJB:编写分布式业务应用程序的Java标准架构。提供大量服务:声明型事务, EIB容器自动启动、提交和回滚事务。业务逻辑能参与由远程客户发起的分布式事务。提供声明型安全,大部分情况下不再摇要编写安全代码求(bean部署描述符里的条目指定准可以防问某个具体bean)。,.,60,例:在两个账号间进行转账的服务。,.,61,POJO(业务逻辑) +Hiibernate、JDO、iBATIS(持久化)、Spring(事务管理、安全)。 典型的EJB方法 POJO方
20、法 组织 过程式业务逻辑 面向对象设计 实现 基于EJB POJO 数据库访问 JDBC/SQL或实体bean 持久层框架 返回给表示层的数据DTO 业务对象 事务管理 EJB容器管理的事务 Spring框架 应用程序组装 显式的JNDI查询 依赖注入 ,.,62,新设计是面向对象、基于POJO, 而非基于EJB的过程式。它使用构建在JDBC上的持久层框架来访问数据库, 并不直接使用JDBC。业务逻辑由POJO facade而非会话bean进行封装。事务由Spring框架而非EJB容器进行管理。业务逻辑向表现层返回实际的业务对象,而不是DTO。应用程序通过将组件的依赖作为setter或构造子参
21、数传入来进行组装,而不是之前采用Java命名和目录接口(JNDI )查询的组件。由于该设计面向对象,并采用上述轻量级技术,因此较之前看到的EJB版本对开发人员要友好。,.,63,基于轻量级框架设计的好处是,它提供事务和持久化时并不要求应用程序类实现任何特殊接口。甚至当应用程序的类需要运行在事务里或是持久的时候,它们仍是POJO,设计者可以继续享受POJO的种种好处。,.,64,.,65,面向对象的优点:整个设计更易理解和维护。它并不是一个无所不能的大型类, 而是由大量小类组成, 每个类只共有若干职责。此外,诸如Account、BankingTransaction和OverdraftPolicy
22、类都与现实世界的概念对应, 因此易于理解。其次,面向对象设汁也更易测试: 所有类都能并且应当进行独立的测试。EJB只能通过调用它的public 方法如Transter进行测试,难度大。(只能测试p-blic方法暴露的复杂功能,无法测试其中简单的部分)。面向对象象设计更易扩展, 它可使用设计模式,如Stategy和Template等。EJB风格的过程式设计往往需耍修改核心代码。,.,66,不适合用面向对象的场合:大量数据集合的关系操作。以数据库为中心的管理程序 :这个领域所对应的现实世界是一个面向关系的世界,表与表的关联体现的是彼此的业务关系。 复杂的SQL固然不好维护,但业务真是复杂到简单的S
23、QL都难以描述的程度,采用面向对象描述则更加困难,维护也更困难,同时还损失了效率。比较大的事务。性能要求高的地方。(直接用Sql或者存储过程;牺牲可维护性和可复用性)上层流程。,.,67,消除DTO,.,68,部署POJO程序,.,69,.,70,.,71,面向对象设计的基本原则,.,72,.,73,liskov替换原则(LSP),.,74,子类型必须能够替换掉其基类型,问题的根源是关于行为的:基类中有的行为在子类中不存在或不适当。IS A的本质是指行为的一致,而不是生活中的语言。违反了LSP原则的本质是派生类的行为与基类中的不一致。如果违反了LSP原则,常会导致在运行时的类型判断(RTTI)
24、违反OCP原则。例如:函数A的参数是基类型,调用时传递的对象是子类型,正常情况下,增加子类型都不会影响到函数A的,如果违反了LSP,则函数A必须小心的判断传进来的具体类型,否则就会出错,这就已经违反了OCP原则。,.,75,违反LSP导致违反OCP的简单例子,.,76,改善,.,77,例:会议管理系统,.,78,例:GUI对象,假定一个Component代表一个GUI对象,如按钮或者文本框等。,.,79,.,80,.,81,改善2,.,82,例,.,83,接口隔离原则(ISP),康凯,.,84,例,.,85,使用委托分离接口,.,86,使用多重继承分离接口,.,87,内接口与外接口,.,88,
25、普通接口与智能接口,.,89,软件系统坏死的症状,.,90,“Copy”程序,一个从键盘读入字符并输出到打印机的程序。void Copy()int c;while (c = RdKbd() != EOF)WrtPtr(c);,.,91,需求在变化,用户希望Copy程序能从纸带读入机中读入信息。现实中的约束不能改变接口Copy程序的第一次修改结果bool ptFlag = false;/remember to reset this flagvoid Copy()int c;while (c = (ptFlag ? Rdpt() : Rdkbd() != EOF)WrtPtr(c);,.,92,需
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 高级 软件 架构 设计 课件
链接地址:https://www.31ppt.com/p-1478844.html