Udostępnij za pośrednictwem


IDiaEnumSymbolsByAddr2

Wylicza według adresów różnych symboli zawartych w źródle danych.

Składnia

IDiaEnumSymbolsByAddr2 : IDiaEnumSymbolsByAdd

Metody w tabeli Vtable Order

W poniższej tabeli przedstawiono metody .IDiaEnumSymbolsByAddr2

Metoda opis
IDiaEnumSymbolsByAddr2::symbolByAddrEx Umieszcza moduł wyliczający, wykonując wyszukiwanie według sekcji i przesunięcia.
IDiaEnumSymbolsByAddr2::symbolByRVAEx Umieszcza moduł wyliczający, wykonując wyszukiwanie według względnego adresu wirtualnego (RVA).
IDiaEnumSymbolsByAddr2::symbolByVAEx Umieszcza moduł wyliczający, wykonując wyszukiwanie według adresu wirtualnego (VA).
IDiaEnumSymbolsByAddr2::NextEx Pobiera następne symbole w kolejności według adresu. Aktualizuje położenie modułu wyliczającego według liczby pobranych elementów.
IDiaEnumSymbolsByAddr2::PrevEx Pobiera poprzednie symbole w kolejności według adresu. Aktualizuje położenie modułu wyliczającego według liczby pobranych elementów.

Uwagi

Ten interfejs udostępnia symbole pogrupowane według adresu. Aby pracować z symbolami pogrupowanych według typu, na przykład SymTagUDT (typ zdefiniowany przez użytkownika) lub SymTagBaseClass, użyj interfejsu IDiaEnumSymbols .

Uwagi dla osób wywołujących

Uzyskaj ten interfejs, wywołując metodę IDiaSession::getSymbolsByAddr , a następnie wywołując IUnknown::QueryInterface parametr z parametrem ustawionym riid na IID_IDiaEnumSymbolsByAddr2.

Przykład

Ta funkcja wyświetla nazwę i adres wszystkich symboli uporządkowanych według względnego adresu wirtualnego.

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 );
    }
}

Wymagania

Nagłówek: Dia2.h

Biblioteka: diaguids.lib

BIBLIOTEKA DLL: msdia140.dll

Zobacz też