IDataModelManager3::CreateIntrinsicObject 方法 (dbgmodel.h)

CreateIntrinsicObject 方法是将内部值装入 IModelObject的方法。 调用方将值放在 COM VARIANT 中,并调用此方法。 数据模型管理器返回表示对象的 IModelObject。 请注意,此方法还用于装箱基于 IUnknown 的基本类型:属性访问器、方法、上下文等...在这种情况下,objectKind 方法指示对象表示的基于 IUnknown 的构造类型,传递的变体的 punkVal 字段是 IUnknown 派生类型。 该类型必须静态转换为相应的模型接口(例如:IModelPropertyAccessorIModelMethodIDebugHostContext等)。处理中。

此方法支持的 VARIANT 类型包括VT_UI1、VT_I1、VT_UI2、VT_I2、VT_UI4、VT_I4、VT_UI8、VT_I8、VT_R4、VT_R8、VT_BOOL、VT_BSTR和VT_UNKNOWN(适用于枚举 ModelObjectKind 指示的专用 IUnknown 派生类型集)。

语法

HRESULT CreateIntrinsicObject(
  ModelObjectKind objectKind,
  VARIANT         *intrinsicData,
  IModelObject    **object
);

参数

objectKind

指示正在装箱的对象的类型。 对于因变体类型而异的普通内部函数,请在此处传递 ObjectIntrinsic。 对于实际上为 IUnknown 派生接口的其他接口,对象类型是 ModelObjectKind 枚举中的值之一,VARIANT 中的接口必须匹配。

intrinsicData

一个 VARIANT,其中包含要在 IModelObject 容器内装箱的值。

object

新装箱值(作为 IModelObject)将在此处返回。

返回值

此方法返回指示成功或失败的 HRESULT。

言论

示例代码

ComPtr<IDataModelManager3> spManager; /* get the data model manager */

VARIANT vtValue;
vtValue.vt = VT_I4;
vtValue.lVal = 42;

// If the object is an VT_UNKNOWN, the first argument to CreateIntrinsicObject
// indicates what KIND of IUnknown.  For example, ObjectPropertyAccessor would 
// indicate IModelPropertyAccessor.  ObjectMethod would indicate IModelMethod, etc...
ComPtr<IModelObject> spValue;
if (SUCCEEDED(spManager->CreateIntrinsicObject(ObjectIntrinsic, &vtValue, &spValue)))
{
    // spValue now contains the object (boxed) representation of the int value 42.
}

要求

要求 价值
标头 dbgmodel.h

另请参阅

IDataModelManager3 接口