为什么通过同一COM对象的不同接口检索到的IUnknown*指针具有相同的值?
Why do IUnknown* pointers retrieved through different interfaces of the same COM object have the same value?
我有以下COM接口层次结构和实现它们的类:
interface IX : public IUnknown{};
interface IY : public IUnknown{};
class CA: public IX, public IY{};
这里class CA
有效地从IUnknown
继承了两次。
我们知道class CA
中有两个虚表指针,一个指向IX
,另一个指向IY
。因此,IX
子对象中存储的IUnknown
与IY
子对象中存储的IUnknown
是不同的。
然而,当我们在同一个对象上调用IX::QueryInterface()
或IY::QueryInterface()
并查询IUnknown
时,我们得到相同的IUnknown*
指针。
为什么会发生?
这就是所谓的"对象同一性"要求,即无论何时从两个对象请求IUnknown
,如果它们是不同的对象,则得到不同的指针,如果它们是相同的对象,则得到相等的指针。
每个QueryInterface()
实现都必须满足这个要求。这通常是通过选择返回哪个IUnknown
并坚持使用它来完成的:
HRESULT CA::QueryInterface( REFIID iid, void** ppv )
{
if( iid == __uuidof( IUnknown ) ) {
// Explicitly cast to one of base class subobjects.
// Doesn't matter which one is chosen - it just has to be
// the same base class subobject each time IUnknown is requested.
IUnknown* selected = static_cast<IX*>( this );
*ppv = selected;
AddRef();
return S_OK;
} else {
continue for other interfaces
}
}
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 为什么使用 "this" 指针调用派生成员函数?
- 函数向量_指针有不同的原型,我可以构建一个吗
- 使用指针从C++中的数组中获取最大值
- 助记符和指向成员语法的指针
- 嵌入方指针压缩已禁用
- 数组的指针从不分段故障
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 何时在引用或唯一指针上使用移动语义
- QMetaObject invokeMethod的基于函数指针的语法
- 如何从 std::atomic 中提取指针 T<T>?
- 如何在 C# 中映射双 C 结构指针?
- C++将浮点指针值舍入为小数位数
- 为什么++(*p)更改指针值
- 调整大小后指向元素值的指针unordered_map有效?
- 正在将指针转换为范围
- 使用指向成员的指针将成员函数作为参数传递
- 将 DirectX 接口强制转换为 IUnknown 指针
- 为什么通过同一COM对象的不同接口检索到的IUnknown*指针具有相同的值?