Compartilhar via


Função EnumerateCLRs

Fornece um mecanismo para enumerar os CLRs em um processo.

Sintaxe

HRESULT EnumerateCLRs (
    [in]  DWORD      debuggeePID,
    [out] HANDLE**   ppHandleArrayOut,
    [out] LPWSTR**   ppStringArrayOut,
    [out] DWORD*     pdwArrayLengthOut
);

Parâmetros

debuggeePID
[in] Identificador de processo do processo do qual CLRs carregados serão enumerados.

ppHandleArrayOut
[out] Ponteiro para uma matriz que contém identificadores de evento que são usados para continuar uma inicialização de CLR. Não é garantido que cada identificador na matriz seja válido. Se válido, o identificador será usado como evento de inicialização contínua para o runtime correspondente localizado no mesmo índice de ppStringArrayOut.

ppStringArrayOut
[out] Ponteiro para uma matriz de cadeias de caracteres que especificam caminhos completos para CLRs carregados no processo.

pdwArrayLengthOut
[out] Ponteiro para um DWORD que contém o comprimento de ppHandleArrayOut e pdwArrayLengthOut, que são de igual tamanho.

Retornar valor

S_OK
O número de CLRs no processo foi determinado com êxito e as matrizes de identificador e caminho correspondentes foram preenchidas corretamente.

E_INVALIDARG
Se ppHandleArrayOut ou ppStringArrayOut for nulo ou pdwArrayLengthOut for nulo.

E_OUTOFMEMORY
A função não consegue alocar memória suficiente para as matrizes de identificador e caminho.

E_FAIL (ou outros códigos de retorno E_)
Não é possível enumerar CLRs carregados.

Comentários

Para um processo de destino identificado por debuggeePID, a função retorna uma matriz de caminhos, ppStringArrayOut, para CLRs carregados no processo; uma matriz de identificadores de evento, ppHandleArrayOut, que pode conter um evento de inicialização contínua para o CLR no mesmo índice; e o tamanho das matrizes, pdwArrayLengthOut, que especifica o número de CLRs que são carregados.

No sistema operacional Windows, debuggeePID mapeia para um identificador de processo do sistema operacional.

A memória para ppHandleArrayOut e ppStringArrayOut é alocada por essa função. Para liberar a memória alocada, você deve chamar a Função CloseCLREnumeration.

Essa função pode ser chamada com ambos os parâmetros de matriz definidos como nulos para retornar a contagem de CLRs no processo de destino. Nessa contagem, um chamador pode inferir o tamanho do buffer que será criado: (sizeof(HANDLE) * count) + (sizeof(LPWSTR) * count) + (sizeof(WCHAR*) * count * MAX_PATH).

Requisitos

Plataformas: confira Sistemas operacionais com suporte no .NET.

Cabeçalho: dbgshim.h

Biblioteca: dbgshim.dll, libdbgshim.so, libdbgshim.dylib

Versões do .NET: disponível desde o .NET Core 2.1