IDataModelManager::CreateIntrinsicObject 方法 (dbgmodel.h)
CreateIntrinsicObject 方法是将内部值装入 IModelObject 的方法。 调用方将值放在 COM VARIANT 中并调用此方法。 数据模型管理器返回表示对象的 IModelObject 。 请注意,此方法还用于装箱基于 IUnknown 的基本类型:属性访问器、方法、上下文等...在这种情况下,objectKind 方法指示对象表示的基于 IUnknown 的构造的类型,传递的变体的 punkVal 字段是 IUnknown 派生类型。 类型必须静态强制转换为相应的模型接口 (例如: IModelPropertyAccessor、 IModelMethod、 IDebugHostContext 等...) 正在进行中。
此方法支持的 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 所示。
语法
HRESULT CreateIntrinsicObject(
ModelObjectKind objectKind,
VARIANT *intrinsicData,
IModelObject **object
);
参数
objectKind
指示要装箱的对象的类型。 对于因变体类型而异的正常内部函数,此处传递 ObjectIntrinsic。 对于其他实际上是 IUnknown 派生接口的接口,对象类型是 ModelObjectKind 枚举中的值之一,VARIANT 中的接口必须匹配。
intrinsicData
一个 VARIANT 类型的值,该值将装箱在 IModelObject 容器中。
object
此处将返回作为 IModelObject) (的新装箱值。
返回值
此方法返回指示成功或失败的 HRESULT。
注解
示例代码
ComPtr<IDataModelManager> 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.
}
要求
要求 | 值 |
---|---|
Header | dbgmodel.h |