八年级语文上册com课件.ppt

上传人:飞****2 文档编号:73768454 上传时间:2023-02-22 格式:PPT 页数:32 大小:1.55MB
返回 下载 相关 举报
八年级语文上册com课件.ppt_第1页
第1页 / 共32页
八年级语文上册com课件.ppt_第2页
第2页 / 共32页
点击查看更多>>
资源描述

《八年级语文上册com课件.ppt》由会员分享,可在线阅读,更多相关《八年级语文上册com课件.ppt(32页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、COMCOM第一个第一个COM对象对象例子(G:File内部交流赵国光comExampleDropTarget)IDropTarget的定义 interface IDropTarget:public IUnknown public:virtual HRESULT STDMETHODCALLTYPE DragEnter(/*uniquein*/IDataObject _RPC_FAR*pDataObj,/*in*/DWORD grfKeyState,/*in*/POINTL pt,/*outin*/DWORD _RPC_FAR*pdwEffect)=0;virtual HRESULT STDME

2、THODCALLTYPE DragOver(/*in*/DWORD grfKeyState,/*in*/POINTL pt,/*outin*/DWORD _RPC_FAR*pdwEffect)=0;virtual HRESULT STDMETHODCALLTYPE DragLeave(void)=0;virtual HRESULT STDMETHODCALLTYPE Drop(/*uniquein*/IDataObject _RPC_FAR*pDataObj,/*in*/DWORD grfKeyState,/*in*/POINTL pt,/*outin*/DWORD _RPC_FAR*pdwE

3、ffect)=0;什么是什么是COMCOMComponent Object Model(组件对象模型)微软提出的二进制上的组件标准,定义了对象(组件)之间进行通信的协议。COM是一个更好的C+C+库厂商的麻烦库厂商的麻烦某一个c+库厂商开发生产了一个算法,可以在O(1)时间阶内完成字符串搜索。为了让客户能够简单的使用这个算法,库厂商创建了一个类:FastString示例:faststring.hfaststring.cpp软件分发软件分发传统上,库厂商分发C+库一直以源码的形式进行.问题:代码复制,多个应用使用相同的代码占用磁盘空间以及内存.代码更新,将源码重新分发,重新编译链接,失去了模块化

4、的特征.示意图示意图 应用A 应用C 应用BFastString.objFastString.objFastString.obj动态链接库动态链接库(dll)为了解决重复代码以及更新困难的问题,将FastString类封装为一个dll是一个马上想到的方法._declspec(dllexport)关键字.引入库(import library)示意图示意图应用A应用C应用BFastString.dllDll引入库C+的可移植性的可移植性C+缺少二进制级别的标准编译器和链接器的兼容性名字的问题,链接时表达符号名字名字的问题,链接时表达符号名字为了支持函数重载和操作符重载,不同的编译器/链接器会任意修

5、改入口点的符号名字,称为名字改编(name mangling)使用 extern“C”可以消除名字改编现象,但只对全局函数有效.使用模块定义文件(Module Definition File DEF).在运行时表达语言的不同特征在运行时表达语言的不同特征编译器厂商对语言的特征有不同方式的实现,异常(Exception)是一个例子.封装性的问题封装性的问题假如已经解决了编译器和链接器的问题,建立二进制组件的下一个障碍则和封装有关.FastString的Length方法有问题,修改FastString类的定义.FastString dll升级为2.0,解决Length的问题.FastString

6、Dll分版本改名策略.新应用(用修改后的FastString)旧应用FastString.dll(2.0)接口与实现的分离接口与实现的分离封装的基础在C+中,这个原则没有应用到二进制层,因为C+类即是接口也是实现.如何做到接口与实现的分离将接口与实现分立成两个实体,在c+中表现为两个类,接口类和实现类.接口类只对一定的数据类型进行描述.实现类对数据类型作具体的实现.接口类的定义faststringitf.hclass FastString;class _declspec(dllexport)FastStringInf private:FastString*m_pObj;public:FastS

7、tringInf(const char*psz);FastStringInf();int Length()const;int Find(const char*psz)const;示例:G:File内部交流赵国光comExamplefaststringdll2使用面向对象的特性使用面向对象的特性编译器/链接器的问题依然没有解决。利用所有编译器/链接器的一致性。复合结构在运行时表现形式对不同编译器一致.所有编译器使用相同的堆栈规则传递参数.所有所有C+编译器实现相同的虚函数调用机制编译器实现相同的虚函数调用机制.也就是说对每个也就是说对每个c+编译器来说,一个对象在内存中编译器来说,一个对象在内存

8、中如何表示,以及在运行时怎样调用虚函数都必须一致如何表示,以及在运行时怎样调用虚函数都必须一致以上三条假设所有编译器必须要遵从.使用抽象基类作为二进制接口使用抽象基类作为二进制接口vptr以及vtbladjustor thunk(win32),CFRONT(solaris)vptrv_fun1v_fun2v_fun3vtblIFastString/接口接口FastString的抽象基类class IFastStringpublic:virtual int Length()const=0;virtual int Find(const char*psz)const=0;vptrLengthFind

9、vtblIFastString内存结构FastString/实现实现class FastString public:IFastStringprivate:const int m_cch;char*m_psz;public:FastString(const char*psz);FastString(void);int Length(void)const;int Find(const char*psz)const;vptr LengthFindvtblFastString内存结构m_cchm_psz唯一的全局函数唯一的全局函数extern“C”IFastString*CreateFastStrin

10、gObject(const char*psz)return new FastString(psz);new方法在dll内部被调用。析构函数的问题析构函数的问题考虑如下用法:IFastString*fs=CreateFastStringObject(“hellow everyone”);if(fs)int pos=fs-Find(“very”);delete fs;问题:内存泄露。原因:IFastString的析构函数并不是虚函数。解决办法:显示的使用删除方法删除自身。示例:G:File内部交流赵国光comExamplefaststringdll3动态载入动态载入dll的好处的好处减少应用程序初

11、始化的工作。dll不存在也不会导致系统出现错误。在运行时动态选择不同的实现。(另外的意义是组件升级)功能升级扩展带来的问题功能升级扩展带来的问题接口的改变或增加都可能导致客户代码重新编译。class IFastString public:virtual int Delete(void)=0;virtual int Length()const=0;virtual int Find(const char*psz)const=0;/新功能virtual int FindN(const char*psz)const=0;新方法追加在接口定义的尾部,老客户使用新服务可以,反过来则会崩溃。实现类暴露多个接

12、口接口从另一个接口继承实现类从多个接口继承运行时类型识别(RTTI),dynamic_cast.接口继承接口继承继承接口类定义:class IFastString2:public IFastStringpublic:virtual int FindN(const char*psz)const=0;运行时类型识别用法:int FindNth(IFastString*fs,int n)IFastString2*fs2=dynamic_cast(fs);if(fs2)jreturn fs2-FindN(“very”,n);elseerror(“类型转换失败,不能进行查找”);/或者用别的实现retu

13、rn-1;接口继承接口继承2 永久性支持永久性支持/永久性对象class IPersistObjectpublic:virtual void Delete()=0;virtual bool Load(const char*filename)=0;virtual bool Save(const char*filename)=0;/支持永久性的Faststringclass FastString:public IFastString,public IPersistObject private:int m_cch;char*m_psz;public:FastString(const char*psz

14、);FastString(void);void Delete(void);/IFastString 的方法int Length(void)const;int Find(const char*psz)const;/IPersistObject 的方法bool Load(const char*filename);bool Save(const char*filename);bool SaveString(IFastString*fs,char*filename)IPersistObject*po=dynamic_cast(fs);if(po)return po-Save(filename);els

15、e return false;RTTI的问题的问题RTTI 是与编译器相关的特性,不同的变异其厂商对其有着不同的实现。这样就破坏了以抽象基类作为接口而获得的编译器独立性。解决方法:每个接口自己实现dynamic_cast的功能,这样仍然保持编译器独立性。修改后的接口类修改后的接口类class IPersistObjectpublic:virtual void*Dynamic_Cast(const char*type)=0;virtual void Delete()=0;virtual bool Load(const char*filename)=0;virtual bool Save(cons

16、t char*filename)=0;class IFastStringpublic:virtual void*Dynamic_Cast(const char*type)=0;virtual void Delete()=0;virtual int Length()=0;virtual int Find(const char*psz)=0;/extract methodclass IBaseObjectpublic:virtual void*Dynamic_Cast(const char*type)=0;virtual void Delete()=0;实现实现Dynamic_Cast方法方法cl

17、ass FastString:public IFastString,public IPersistObject/;void*FastString:Dynamic_Cast(const char*type)if(strcmp(type,”IFastString”)=0)return static_cast this;else if(strcmp(type,”IPersistObject”)=0)return static_cast this;else if(strcmp(type,”IBastObject”)=0)return static_castthis;/?return NULL;转为IF

18、astString的原因:多继承引起的二义性。消除多继承引起的二义性可以使用虚基类技术,但c+里虚基类同样是编译器相关的特性。资源管理资源管理void f(void)IFastString*pfs=0;IPersistObject*ppo=0;pfs=CreateFastString(“Hello every body.);if(pfs)ppo=(IPersistObject*)pfs-Dynamic_Cast(IPersistObject);if(!ppo)pfs-Delete();else ppo-Save(C:test.txt);ppo-Delete();问题问题创建的对象是IFastS

19、tring指针接收的,但却是用IPersistObject接口Delete,并且对象只能被释放一次。在此,由于他们都是指向的同一个对象,所以资源释放没问题,但是如果在复杂的代码中,包含多个接口,多个对象的时候,资源释放将变得非常复杂和不易控制。解决方法:将资源释放部分放到实现内部,每个对象自己控制自己的生命周期。Delete方法的改造方法的改造/基类抽象接口class IBaseObjectvirtual void*Dynamic_Cast(const char*type);/virtual void Delete(void);virtual void AddPointer();virtual

20、 void DelPointer();/实现实现类维护一个变量,在指针复制的时候增加,指针不用的时候减少,减至0时将对象销毁。class FastString:public IFastString,public IPersistObjectint m_pcount;public:void AddPointer()m_pcount+;void DelPointer()if(-m_pcount=0)delete this;接下来需要修改管理指针的接口,在指针被复制的时候调用AddPointer.对FastString Dll来说,有两个地方需要修改,一是创建对象接口CreateFastString

21、Object,一是运行时动态类型转换接口Dynamic_Castvoid*FastString:Dynamic_Cast(const char*type)void*obj=NULL;if(strcmp(type,”IFastString”)=0)obj=static_cast this;else if(strcmp(type,”IPersistObject”)=0)obj=static_cast this;else if(strcmp(type,”IBastObject”)=0)obj=static_castthis;/?elsereturn NULL;if(obj)(IBaseObject*

22、)obj)-AddPointer();return obj;extern“C”IFastString*CreateFastStringObject(const char*psz)IFastString*fs=new FastString(psz);fs-AddPointer();return fs;客户端用法客户端用法void f(void)IFastString*pfs=0;IPersistObject*ppo=0;pfs=CreateFastString(“Hello every body.);if(pfs)ppo=(IPersistObject*)pfs-Dynamic_Cast(IPersistObject);if(ppo)ppo-Save(C:test.txt);ppo-DelPointer();pfs-DelPointer();结束结束1,用dll发布FastString。2,将接口和实现分离,使修改实现类无需重新编译客户系统。3,采用抽象基类作为二进制接口。4,运行时可动态选择同一接口的不同实现。(LoadLibrary)5,仿RTTI,实现Dynamic_Cast,运行时查询接口。6,谢谢。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁