隔离 MFC 公共控件库
公用控件库现在在 MFC 中处于隔离状态,通过在其清单中指定版本,允许不同模块(如用户 DLL)使用不同版本的公用控件库。
MFC 应用程序(或 MFC 调用的用户代码)通过名为 Afx
FunctionName(其中 FunctionName 是公共控件 API 的名称)的包装器函数调用公共控件库 API。 这些包装器函数是在 afxcomctl32.h 和 afxcomctl32.inl 中定义的。
可以使用 AFX_COMCTL32_IF_EXISTS 和 AFX_COMCTL32_IF_EXISTS2 宏(在 afxcomctl32.h 中定义)来确定公共控件库是否实现特定 API,而不是调用 GetProcAddress。
从技术上说,您可以通过包装器类 CComCtlWrapper
(在 afxcomctl32.h 中定义)调用公共控件库 API。 CComCtlWrapper
还负责加载和卸载 comctl32.dll。 MFC 模块状态包含指向 CComCtlWrapper
实例的指针。 您可以使用 afxComCtlWrapper
宏来访问包装器类。
请注意,直接(不使用 MFC 包装器函数)从 MFC 应用程序或用户 DLL 调用公共控件 API 在大多数情况下有用,因为 MFC 应用程序或用户 DLL 将绑定到其在清单中请求的公共控件库。 但是,MFC 代码本身必须使用包装器,因为 MFC 代码可能是从使用不同公共控件库版本的用户 DLL 调用的。