潘爱民Com课件PPT01

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

组件技术潘爱民北京大学计算机研究所2003-9-12内容关于本课程软件技术的发展当前软件状况COM和CORBA简介本课程的内容和安排(optional)基础:C++Overview关于本课程历史:–2001年上半年请参考–2002年下半年请参考–这学期的变化和调整保留COM和Pattern部分,增加一些新的内容动机:–加强基础–展示先进的软件技术–提高软件设计能力课程的风格计算机科学的本质计算机的定义–冯-诺伊曼定义:defineacomputerasadevicethatacceptsdata,processesdata,storesdata,andproducesoutput.–指令流处理方式本质:–动态——计算–静态——存储软件领域的发展程序设计方法的发展软件需求的变化软件环境的变化软件开发模式的变化程序设计方法的发展功能分解法——计算任务结构化程序设计——以数据为中心面向对象程序设计——以对象为中心组件程序设计——以组件为中心综合使用软件需求的变化计算实用管理(MIS)分布式系统软件环境的变化单任务多任务文字界面图形界面单线程多线程平台相关跨平台单机(本地)网络(分布式)单一语言多种语言软件开发模式机器码高级语言和脚本代码OS+Compiler+EditorOS+Compilers+IDEs+Libraries+Wizards+Components+otherinforstructures+经验发展变化的结果软件学科的形成不变因素:–计算机的基本运作模式探求新的计算模型–量子计算——软件学科怎么办?–生物信息学(?)回顾软件学科10多年来的变化软件的产生过程:原始代码-编译-Link-终代码、脚本—混合软件的分发过程:文档、说明书、自动安装工具、培训、升级软件工程:需求-〉分析-〉设计-〉code-test-使用对象技术和组件技术的不断普及,与大环境发展相结合对象技术用一种新的思路来看待问题–10多年的发展证明了OO符合软件的规律–对象技术的发展需要开发工具和开发语言的支持三大特性:封装性、继承性、多态性两种思想–Object-Based–Object-Oriented组件技术组件技术适合于现代的软件环境–软件更新快、规模大、强调协作等–组件的概念、软件IC组件的可独立发布性要求“接口与实现分离”组件infrastructure,组件体系–COM、CORBA(和Java)、.NET中间件(middleware)市场国内的状况在对象技术和组件技术方面,国内还是落后问题:–好的技术没能及时引进来(怎么引进来?)–缺乏好的教材、技术杂志、技术书籍(?)–缺乏良好的教育环境和工业环境基础编译过程,程序产生的过程–回归“冯-诺伊曼”模型C++之必要性:–最能反映对象技术、组件技术的核心概念–存在的问题:缺乏好的书籍——现在不缺了国内的应用领域不够广泛概念:类、对象类是定义,它封装了状态和操作对象是实例,它反映了具体的事物对象由类来定义一个对象可以与多个具有继承关系的类相联系概念:组件定义:可独立发布的二进制单元有的地方称作“package”容易混淆:–服务器(server)、对象例如:–COM组件、JavaApplet概念:reuse(重用、复用)软件设计的目标不同形式的reuse不同层次的代码reuse例子:–类库、中间件概念:接口与实现分离Interfaceandimplementation对象技术和组件技术都强调–实际上,计算机定义的本身也强调了这一点接口是对象或者组件的通信协议实现是对象或者组件的内部细节接口的发布客户只关心接口概念:decouple去耦尽可能地消除软件之间或者软件的不同部分之间的联系是软件设计的重要手段,也是目标不同层次上的decouple概念:多态性(polymorphism)对象技术中的重要概念以一致的方式来看待不同的事物在C++中,通过继承和虚成员函数来实现运行时刻绑定:runtimebinding–区分两个词:overloadvs.override在组件技术中,通过接口来体现概念:module模块不同层次上有不同的定义在Windows和Linux中,指可独立装载的二进制代码单元有些操作与模块相关概念:模板(template)函数模板和类模板抽象层次更高泛型技术(genericprogramming)已纳入C++标准之中例子:–STL、ATL概念:C/S和多层结构这是指软件的结构C/S是基础多层结构具有较好的灵活性和可扩展性多层结构与基于组件的系统相结合变种:–B/S概念:软件层次思想垂直层次–多层结构属于水平分层层次之间采用“接口与实现”分离的原则–网络协议栈是一个很好的例子理解层次的思想有助于理解整个系统或者整个应用–对于计算机而言,层次是逻辑的,它是计算机软件领域中的发展空间–层次使得软件更加有序、有组织、有条理–层次的代价:效率、体积庞大overlay概念:虚拟机虚拟机技术本身是层次思想的一种体现形式一种典型的overlay概念:其他现代软件的发展形成了很多重要的概念掌握这些概念对于提高自己的软件理解水平非常重要防止混淆和滥用概念软件形式单机软件–整体发布Client/Server软件–简单的网络应用分布式软件-〉Service软件发展面临的问题软件的复杂度增加–代码开发管理软件升级和更新–牵一而发动全身?分布式软件的发布和配置–用户需要培训,程序员和设计人员更需要Internet软件–Service的安全性–*Agent和Worm软件发展面临的问题(续)Custom-madeversusstandardsoftware–如何平衡?依赖于全才开发人员–软件层次划分软件的可扩展性–用户可定制、脚本支持与标准接轨–如Web——〉B/S软件发展趋势组件软件、软件组件–中间件市场已经形成软件基础设施的重要性–经验和成果的重用软件的可重用性要求–重用粒度不同API的多样化软件方案(solution),consulting市场组件软件部分升级–补丁–缩短软件的更新周期增加了异构软件的可能–标准接口、标准规范、标准协议动态组合,提高软件生产力符合现代软件的发展要求软件组件关键:接口设计–接口不变性–接口可扩展性对基础设施的依赖–COM、CORBA、...内部独立设计、独立开发独立发布、独立测试基础设施:组件体系COM(ComponentObjectModel)–93年发布,脱胎于MS的OLE–规范+实现CORBA(CommonObjectRequestBrokerArchitecture)–91年第1版,OMG(ObjectManagementGroup)–规范+实现COM:组件对象模型建立在二进制层次上的标准–许多概念与C++的特征相似,如vtable–程序与程序之间的通信建立在此基础上COM规范–平台无关–定义了大量的标准接口用于各种用途COM实现–平台相关–Windows实现了规范要求以及许多辅助功能COM特性语言无关–规范和实现都是语言无关的进程透明——〉位置透明–inprocserver、out-of-procserver可重用性多线程特性可扩展性COM:接口COM接口–IID:128位整数–接口定义语言COMIDL–对应于C++中由纯虚函数组成的类–单继承,基接口:IUnknownCOM接口特性:–接口不变性–继承性–多态性——运行时刻的多态性COM:对象COM对象–CLSID–实现多个接口COM对象特性:–身份确定–封装–可重用ObjectIUnknownInterface1Interface2COM:组件COM对象的载体–包含多个COM对象进程内组件–DLL–ExportEntrys进程外组件–IPC:RPC/LPCCOM:进程内组件Inprocserver–ExportEntrys客户组件COM:进程外组件Out-of-procserver客户COM运行库安全提供器LPCDCERPCCOM运行库安全提供器LPCDCERPC组件客户程序(客户进程)代理对象组件程序(组件进程)存根代码LPC/RPC组件对象COM:远程组件remoteserver客户COM运行库安全提供器协议栈DCERPCCOM运行库安全提供器协议栈DCERPC组件DCOM网络协议COM:组件信息发布注册表–发布组件的信息、对象的信息、接口的信息等注册工具和配置工具–Regsvr32.exe–.reg–自注册-RegServer–DCOMCNFG.EXE–MTSExplorer、活动目录COM:创建COM对象对象的创建过程客户组件COM库(OLE32.DLL)SCM(RPCSS.EXE)SCM(RPCSS.EXE)RPC调用创建函数远程创建创建进程和对象COM:COM对象管理客户使用规则,控制对象生命周期COM实现优化–各种辅助手段组件类别componentcategoryMTS和COM+COM:COM体系基本的功能扩展功能–连接点–结构化存储–名字服务–自动化–其他COM+COM:COM+建立在COM的基础上,COM的自然延伸Services–事件服务–队列服务–事务服务–负载平衡–其他COM:应用OLEActiveXcontrol脚本功能扩展OLEDBADSIASP其他COM:分布式应用COM/COM+为基于Windows的分布式应用提供了基础设施–Transaction–Security–OLEDB–Web–集成ActiveDirectory–管理功能CORBAOMG,800多家厂商联合制定的标准–91年1.0,主要是C语言映射–95年2.0,加入IIOP–最新版本3.0CORBA规范–制订了互操作规范,上层标准协议–一系列映射到多种语言的规范–各种服务相关的规范CORBA实现:ORBCORBA体系结构CORBA:跨平台、跨语言典型的语言:C++语言、Java语言、Smalltalk多种平台–关键:IOR(InteroperableObjectreference)ORB实现部分ORB实现商业ORB–Orbix,IONA公司–Visibroker,Inprise公司,4.0版完全支持2.3规范Netscapecommunicator浏览器嵌入Visibroker自由ORB–ORBit,遵循CORBA2.2规范,支持C语言,性能较高–mico,GNU,OpenSource–TAO,美国华盛顿大学分布式对象计算研究小组–omniORB,AT&T剑桥实验室国产ORB–国防科大的嵌入式CORBA(eBus)–东南大学的ORBUSCORBA:客户客户通过stub或者CORBA库与对象或者ORB进行通信CORBA:对象对象与OA进行通信CORBA:C++映射开发过程编写IDLIDL-〉C++利用生成的stub类编写客户利用生成的impl类编写服务器对象{以字符串形式传递OR}CORBA:核心CORBAIDL–支持多继承–支持结构化数据类型字符串形式的ORPOA–CORBA对象的环境context–策略设置CORBA:核心(续)GIOP(GeneralInter-ORBProtocol)–互操作协议框架–IIOP(InternetInter-ORBProtocol)IOR–CORBA对象的标识实现仓库、接口仓库–未标准化CORBA:服务命名服务–层次命名–绑定TradingService–功能更

1 / 63
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功