一.包容
如同适配器,调用方法时,调用内部接口方法,对其内部接口进行了封装
// Interface IY virtual void __stdcall Fy() { m_pIY->Fy() ;} //@N
二.聚合
特殊的包容形式,把内部的接口指针直接暴露给外部
HRESULT __stdcall CA::QueryInterface(const IID& iid,void** ppv) { if (iid == IID_IUnkNown) { *ppv = static_cast<IUnkNown*>(this) ; } else if (iid == IID_IX) { *ppv = static_cast<IX*>(this) ; } else if (iid == IID_IY) { trace("Return inner component's IY interface.") ; #if 1 // You can query for the interface. return m_pUnkNownInner->QueryInterface(iid,ppv) ; //@N #else // Or you can return a cached pointer. *ppv = m_pIY ; //@N // Fall through so it will get AddRef'ed #endif } else { *ppv = NULL ; return E_NOINTERFACE ; } reinterpret_cast<IUnkNown*>(*ppv)->AddRef() ; return S_OK ; }
http://www.yesky.com/74/1754074.shtml
包容
http://www.cnblogs.com/shipfi/archive/2007/02/15/651294.html
http://blog.csdn.net/insidekernel/archive/2008/03/11/2169599.aspx
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。