文档详情

大三上分布式可连接对象.pptx

发布:2024-08-29约1.51万字共32页下载文档
文本预览下载声明

1-31十四.可连接对象概念与模型轮询通知出接口连接点机制IConnectionPointContainer接口IConnectionPoint接口接收器的实现连接过程连接过程事件的激发与处理IDiapatch出接口MFC对连接的支持宏事件激发例子:用MFC实现源对象例子:用MFC实现接收器

2-311模型与概念1.1轮询假设有一个这样的接口IWaiter.[object,uuid(2756E11C-A606-482F-969C-14153E1D1601)]interfaceIWaiter:IUnknown{HRESULTBeginWork(void);//这是一项很费时的任务,如果是同步执行,客户必须等待它完成.我们假设它是异步地执行的,客户发出指令后,即刻返回,对象有可能另开辟新的线程进行处理.比如是一个数据库的处理或者是一个科学计算任务.完成以后,客户也得不到任何信息.HRESULTIsOK([out,retval]BOOL*yon);//刚才吩咐的任务完成了吗?}

在这样的设计模式下,客户的使用方法:IWaiter*pIW;hr=CoCreateInstance(CLSID_Waiter,IID_IWaiter,pIW);pIW-BiginWork();//下达命令BOOLDone=false;while(!Done){Sleep(10000);//无奈地等待pIW-IsOK(Done);//再问一次}3-31

4-31更有效的做法是,由客户提供一个接口,这个接口可以供Waiter使用.(留下一个电话号码,做完了通知我!)[object,uuid(2756E11C-A606-482F-969C-14153E1D1602)]interfaceINotify:IUnknown{HRESULTOnWorkIsOk(void);}我们希望Waiter在完成任务以后能够及时地告知客户,而不是让客户一遍遍的轮询.客户要有一种方法把这个接口告诉waiter.修改IWaiter接口如下:[object,uuid(2756E11C-A606-482F-969C-14153E1D1601)]interfaceIWaiter:IUnknown{HRESULTBeginWork(void);HRESULTAdvise([in]INotify*pIN),[out]DWORD*pdwCookie);//客户通过Advise方法提供与此接口任务相关的接口INotify,而Waiter则返回一个代表这种关联的DWORD值.以后,这个值将被用来解除这种关联使用.HRESULTUnAdvise([in]dwCookie);//客户使用UnAdvise通知Waiter解除与INotify的关联.(嗨,别再烦我了!)}1.2通知

5-31CWaiter对IWaiter的实现方法,首先定义一个成员变量INotify*m_pIN;HRESULTCWaiter::Advise(INotify*pIN),DWORD*pdwCookie){if(m_pIN!=NULL)returnE_UNEXPECTED;//已经跟别的对象关联上了.m_pIN=pIN;//保存对通知对象的引用,通知对象在客户端.Waiter作为客户端的通知对象的客户!m_pIN-AddRef();//添加引用计数*pdwCookie=DWORD(m_pIN);//记录下这种关联returnS_OK;}HRESULTCWaiter::UnAdvise(DWORDdwCookie){if(DWORD(m_pIN)!=dwCookie)returnE_UNEXPECTED//核对一下如果不是当前关联的对象.m_pIN-Release();//减少引用计数m_pIN=NULL;//再清空returnS_OK;}

6-31HRESULTCWaiter::BeginWork(void){assert(m_pIN)//确保已经有了关联….//费时的任务m_pIN-OnWorkIsOk();//作完了,通知客户,免得它等得心焦}异步的通知:CNotify::OnWorkIsOk(){MessageBox(“Wakeup!,YourworkisOK!”);//当pIW完成工作以后通过通告接口调用此函数以通知客户.……}而客户此时的使用则是:INotify*m_pIN=newCNotify;IWait

显示全部
相似文档