SWbemObject.SubclassesAsync_ 方法
SWbemObject 的 SubclassesAsync_ 方法异步提供当前对象的子类,该子类必须是类。
有关此语法的说明,请参阅脚本 API 的文档约定。
语法
SWbemObject.SubclassesAsync_( _
ByVal objWbemSink, _
[ ByVal iFlags ], _
[ ByVal objWbemNamedValueSet ], _
[ ByVal objWbemAsyncContext ] _
)
parameters
-
objWbemSink [in]
-
必需。 异步接收对象的对象接收器。
-
iFlags [输入参数,可选]
-
确定该调用枚举的详细程度。 此参数可以接受以下值。
-
wbemQueryFlagDeep (0 (0x0))
-
强制以递归方式枚举派生自指定父类的所有子类。 父类本身不在枚举中返回。
-
wbemQueryFlagShallow (1 (0x1))
-
此参数的默认值。 它强制枚举只包含指定父类的直系子类。
-
wbemFlagSendStatus (128 (0x80))
-
导致异步调用将状态更新发送到对象接收器的 SWbemSink.OnProgress 事件处理程序。
-
wbemFlagDontSendStatus (0 (0x0))
-
防止异步调用将状态更新发送到对象接收器的 OnProgress 事件处理程序。
-
wbemFlagUseAmendedQualifiers (131072 (0x20000))
-
使 WMI 返回类修改数据以及基类定义。 有关已修正的限定符的详细信息,请参阅本地化 WMI 类信息。
objWbemNamedValueSet [输入参数,可选]
通常,未定义此参数。 如果已定义,此参数是一个 SWbemNamedValueSet 对象,其元素表示可供提供请求服务的提供程序使用的上下文信息。 支持或需要此类信息的提供程序必须记录已识别的值名称、值数据类型、允许的值和语义。
objWbemAsyncContext [in, optional]
这是一个 SWbemNamedValueSet 对象,它返回到对象接收器以标识原始异步调用的源。 使用同一对象接收器进行多个异步调用时,请使用此参数。 若要使用此参数,请创建 SWbemNamedValueSet 对象,并使用 SWbemNamedValueSet.Add 方法添加一个值,该值标识即将进行的异步调用。 此 SWbemNamedValueSet 对象返回到对象接收器,并且该调用的源可通过 SWbemNamedValueSet.Item 方法提取。 有关详细信息,请参阅调用方法。
返回值
此方法不返回值。 如果成功,接收器会收到每个实例的 OnObjectReady 事件。 在最后一个实例之后,对象接收器将收到 OnCompleted 事件。
错误代码
SubclassesAsync_ 方法完成后,Err 对象可能包含以下列表中的错误代码之一。
-
wbemErrAccessDenied - 2147749891 (0x80041003)
-
当前用户无权查看调用返回的一个或多个类。
-
wbemErrFailed - 2147749889 (0x80041001)
-
错误。
-
wbemErrInvalidClass - 2147749904 (0x80041010)
-
指定类不存在。
-
wbemErrInvalidParameter - 2147749896 (0x80041008)
-
指定的参数无效。
-
wbemErrOutOfMemory - 2147749894 (0x80041006)
-
内存不足,无法完成此操作。
备注
立即返回此调用。 请求的对象和状态通过回调返回给调用方,该回调传递到 objWbemSink 中指定的接收器。 要在每个对象到达时对其进行处理,请创建 objWbemSink.OnObjectReady 事件子例程。 返回所有对象后,可在 objWbemSink.OnCompleted 事件的实现中执行最终处理。
通过异步回调,未经身份验证的用户可以向接收器提供数据。 这会给脚本和应用程序带来安全风险。 为消除风险,请使用半同步通信或同步通信。 有关详细信息,请参阅调用方法。
建议脚本使用 objWbemAsyncContext 参数来验证调用的源。
如果当前对象没有子类,则返回的集合没有元素不是错误。 SubclassesAsync_ 方法仅适用于类对象。
要求
要求 | 值 |
---|---|
最低受支持的客户端 |
Windows Vista |
最低受支持的服务器 |
Windows Server 2008 |
标头 |
|
类型库 |
|
DLL |
|
CLSID |
CLSID_SWbemObject |
IID |
IID_ISWbemObject |