IDiaEnumSymbolsByAddr2
Enumera in base all'indirizzo i vari simboli contenuti nell'origine dati.
Sintassi
IDiaEnumSymbolsByAddr2 : IDiaEnumSymbolsByAdd
Metodi nell'ordine Vtable
Nella tabella seguente vengono illustrati i metodi di IDiaEnumSymbolsByAddr2
.
metodo | Descrizione |
---|---|
IDiaEnumSymbolsByAddr2::symbolByAddrEx |
Posiziona l'enumeratore eseguendo una ricerca per sezione e offset. |
IDiaEnumSymbolsByAddr2::symbolByRVAEx |
Posiziona l'enumeratore eseguendo una ricerca in base all'indirizzo virtuale relativo . |
IDiaEnumSymbolsByAddr2::symbolByVAEx |
Posiziona l'enumeratore eseguendo una ricerca in base all'indirizzo virtuale (VA). |
IDiaEnumSymbolsByAddr2::NextEx |
Recupera i simboli successivi in base all'ordine in base all'indirizzo. Aggiorna la posizione dell'enumeratore in base al numero di elementi recuperati. |
IDiaEnumSymbolsByAddr2::PrevEx |
Recupera i simboli precedenti in base all'ordine in base all'indirizzo. Aggiorna la posizione dell'enumeratore in base al numero di elementi recuperati. |
Osservazioni:
Questa interfaccia fornisce simboli raggruppati per indirizzo. Per usare i simboli raggruppati per tipo, ad esempio SymTagUDT
(tipo definito dall'utente) o SymTagBaseClass
, usare l'interfaccia IDiaEnumSymbols
.
Note per i chiamanti
Ottenere questa interfaccia chiamando il IDiaSession::getSymbolsByAddr
metodo e quindi chiamando IUnknown::QueryInterface
con il riid
parametro impostato su IID_IDiaEnumSymbolsByAddr2
.
Esempio
Questa funzione visualizza il nome e l'indirizzo di tutti i simboli ordinati in base all'indirizzo virtuale relativo.
void ShowSymbolsByAddress(IDiaSession *pSession)
{
CComPtr<IDiaEnumSymbolsByAddr> pEnumByAddr;
if ( FAILED( psession->getSymbolsByAddr( &pEnumByAddr ) ) )
{
Fatal( "getSymbolsByAddr" );
}
CComPtr<IDiaEnumSymbolsByAddr2> pEnumByAddr2;
if ( FAILED( pEnumByAddr->QueryInterface( IID_IDiaEnumSymbolsByAddr2, &pEnumByAddr2 ) ) )
{
Fatal( "getSymbolsByAddr" );
}
CComPtr<IDiaSymbol> pSym;
if ( FAILED( pEnumByAddr2->symbolByAddrEx( FALSE, 1, 0, &pSym ) ) )
{
Fatal( "symbolByAddr" );
}
DWORD rvaLast = 0;
if ( pSym->get_relativeVirtualAddress( &rvaLast ) == S_OK )
{
pSym = 0;
if ( FAILED( pEnumByAddr2->symbolByRVAEx( FALSE, rvaLast, &pSym ) ) )
{
Fatal( "symbolByAddr" );
}
printf( "Symbols in order\n" );
do
{
CDiaBSTR name;
if ( pSym->get_name( &name ) != S_OK )
{
printf( "\t0x%08X (%ws) <no name>\n", rvaLast );
}
else
{
printf( "\t0x%08X %ws\n", rvaLast, name );
}
pSym = 0;
celt = 0;
if ( FAILED( hr = pEnumByAddr2->NextEx( FALSE, 1, &pSym, &celt ) ) )
{
break;
}
} while ( celt == 1 );
}
}
Requisiti
Intestazione: Dia2.h
Libreria: diaguids.lib
DLL: msdia140.dll