Inicializando o Manipulador de Símbolos

O código a seguir demonstra como inicializar o manipulador de símbolos. A função SymSetOptions adia o carregamento de símbolos até que as informações do símbolo sejam solicitadas. O código carrega os símbolos para cada módulo no processo especificado passando um valor de TRUE para o parâmetro bInvade da função SymInitialize . (Essa função chama a função SymLoadModule64 para cada módulo que o processo mapeou em seu espaço de endereço.)

Se o processo especificado não for o processo chamado SymInitialize, o código passará um identificador de processo como o primeiro parâmetro de SymInitialize.

Especificar NULL como o segundo parâmetro do SymInitialize indica que o manipulador de símbolos deve usar o caminho de pesquisa padrão para localizar arquivos de símbolo. Para obter informações detalhadas sobre como o manipulador de símbolos localiza arquivos de símbolo ou como um aplicativo pode especificar um caminho de pesquisa de símbolos, consulte Caminhos de Símbolo.

DWORD  error;
HANDLE hProcess;

SymSetOptions(SYMOPT_UNDNAME | SYMOPT_DEFERRED_LOADS);

hProcess = GetCurrentProcess();

if (!SymInitialize(hProcess, NULL, TRUE))
{
    // SymInitialize failed
    error = GetLastError();
    printf("SymInitialize returned error : %d\n", error);
    return FALSE;
}