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 do símbolo 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. (Esta função chama o Função SymLoadModule64 para cada módulo mapeado pelo processo 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 de 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ímbolos ou como um aplicativo pode especificar um caminho de pesquisa de símbolos, consulte Caminhos de símbolos.
DWORD error;
HANDLE hCurrentProcess;
HANDLE hProcess;
SymSetOptions(SYMOPT_UNDNAME | SYMOPT_DEFERRED_LOADS);
hCurrentProcess = GetCurrentProcess();
if (!DuplicateHandle(hCurrentProcess, hCurrentProcess, hCurrentProcess, &hProcess, 0, FALSE, DUPLICATE_SAME_ACCESS))
{
// DuplicateHandle failed
error = GetLastError();
printf("DuplicateHandle returned error : %d\n", error);
return FALSE;
}
if (!SymInitialize(hProcess, NULL, TRUE))
{
// SymInitialize failed
error = GetLastError();
printf("SymInitialize returned error : %d\n", error);
return FALSE;
}