Interface IWbemObjectSink (wbemcli.h)
A interface IWbemObjectSink cria uma interface de coletor que pode receber todos os tipos de notificações dentro do modelo de programação do WMI. Os clientes devem implementar essa interface para receber os resultados dos métodos assíncronos da IWbemServices e tipos específicos de notificações de evento. Os provedores usam, mas não implementam essa interface para fornecer eventos e objetos ao WMI.
Normalmente, os provedores chamam uma implementação fornecida a eles pelo WMI. Nesses casos, chame Indicate para fornecer objetos ao serviço do WMI. Depois disso, chame SetStatus para indicar o fim da sequência de notificação. Você também pode chamar SetStatus para indicar erros quando o coletor não tiver nenhum objeto.
Ao programar clientes assíncronos do WMI, o usuário fornece a implementação. O WMI chama os métodos para entregar objetos e definir o status do resultado.
Herança
A interface IWbemObjectSink herda da interface IUnknown . IWbemObjectSink também tem estes tipos de membros:
Métodos
A interface IWbemObjectSink tem esses métodos.
IWbemObjectSink::Indicate Chamado por uma fonte para fornecer uma notificação. |
IWbemObjectSink::SetStatus Chamado por fontes para indicar o fim de uma sequência de notificação ou para enviar outros códigos status para o coletor. |
Comentários
Ao implementar um coletor de assinatura de evento (IWbemObjectSink ou IWbemEventSink), não chame o WMI de dentro dos métodos Indicate ou SetStatus no objeto coletor. Por exemplo, a chamada de IWbemServices::CancelAsyncCall para cancelar o coletor de dentro de uma implementação Indicate pode interferir no estado do WMI. Para cancelar uma assinatura de evento, defina um sinalizador e chame o IWbemServices::CancelAsyncCall de outro thread ou objeto. Para implementações que não estejam relacionadas a um coletor de eventos, como recuperações de objeto, enumeração e consulta, você pode fazer uma chamada de volta para o WMI.
As implementações do coletor devem processar a notificação de evento dentro de 100 milissegundos, pois o thread do WMI que entrega a notificação de evento não pode executar outras tarefas até que o objeto coletor tenha concluído o processamento. Se a notificação exigir uma grande quantidade de processamento, o coletor poderá usar uma fila interna para outro thread a fim de realizar o processamento.
Exemplos
O exemplo de código a seguir é uma implementação simples de um coletor de objetos. Este exemplo pode ser usado com IWbemServices::ExecQueryAsync ou IWbemServices::CreateInstanceEnumAsync para receber as instâncias retornadas:
C++ |
---|
|
Requisitos
Requisito | Valor |
---|---|
Cliente mínimo com suporte | Windows Vista |
Servidor mínimo com suporte | Windows Server 2008 |
Plataforma de Destino | Windows |
Cabeçalho | wbemcli.h (include Wbemidl.h) |
Confira também
Fazer uma chamada assíncrona com C++