IDiaEnumSymbolsByAddr

データ ソースに含まれているさまざまなシンボルをアドレスで列挙します。

構文

IDiaEnumSymbolsByAddr : IUnknown

Vtable 順序のメソッド

次の表に、IDiaEnumSymbolsByAddr のメソッドを示します。

メソッド 説明
IDiaEnumSymbolsByAddr::symbolByAddr セクションとオフセットで検索を実行することにより、列挙子を配置します。
IDiaEnumSymbolsByAddr::symbolByRVA 相対仮想アドレス (RVA) で検索を実行することにより、列挙子を配置します。
IDiaEnumSymbolsByAddr::symbolByVA 仮想アドレス (VA) で検索を実行することにより、列挙子を配置します。
IDiaEnumSymbolsByAddr::Next アドレス順に、次のシンボルを取得します。 取り込まれた要素の数だけ列挙子の位置を更新します。
IDiaEnumSymbolsByAddr::Prev アドレス順に、前のシンボルを取得します。 取り込まれた要素の数だけ列挙子の位置を更新します。
IDiaEnumSymbolsByAddr::Clone オブジェクトのコピーを作成します。

解説

このインターフェイスは、アドレスによってグループ化されたシンボルを提供します。 SymTagUDT (ユーザー定義型) や SymTagBaseClass など、型によってグループ化されたシンボルを操作するには、IDiaEnumSymbols インターフェイスを使用します。

呼び出し元に関する注意事項

このインターフェイスを取得するには、IDiaSession::getSymbolsByAddr メソッドを呼び出します。

この関数は、すべてのシンボルの名前とアドレスを相対仮想アドレス順に表示します。

void ShowSymbolsByAddress(IDiaSession *pSession)
{
    CComPtr<IDiaEnumSymbolsByAddr> pEnumByAddr;
    if ( FAILED( psession->getSymbolsByAddr( &pEnumByAddr ) ) )
    {
        Fatal( "getSymbolsByAddr" );
    }
    CComPtr<IDiaSymbol> pSym;
    if ( FAILED( pEnumByAddr->symbolByAddr( 1, 0, &pSym ) ) )
    {
        Fatal( "symbolByAddr" );
    }
    DWORD rvaLast = 0;
    if ( pSym->get_relativeVirtualAddress( &rvaLast ) == S_OK )
    {
        pSym = 0;
        if ( FAILED( pEnumByAddr->symbolByRVA( 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 = pEnumByAddr->Next( 1, &pSym, &celt ) ) )
            {
                break;
            }
        } while ( celt == 1 );
    }
}

要件

ヘッダー: Dia2.h

ライブラリ: diaguids.lib

DLL: msdia80.dll

関連項目