IDiaEnumSymbolsByAddr2
データ ソースに含まれているさまざまなシンボルをアドレスで列挙します。
構文
IDiaEnumSymbolsByAddr2 : IDiaEnumSymbolsByAdd
Vtable 順序のメソッド
次の表に、IDiaEnumSymbolsByAddr2
のメソッドを示します。
メソッド | 説明 |
---|---|
IDiaEnumSymbolsByAddr2::symbolByAddrEx |
セクションとオフセットで検索を実行することにより、列挙子を配置します。 |
IDiaEnumSymbolsByAddr2::symbolByRVAEx |
相対仮想アドレス (RVA) で検索を実行することにより、列挙子を配置します。 |
IDiaEnumSymbolsByAddr2::symbolByVAEx |
仮想アドレス (VA) で検索を実行することにより、列挙子を配置します。 |
IDiaEnumSymbolsByAddr2::NextEx |
アドレス順に、次のシンボルを取得します。 取り込まれた要素の数だけ列挙子の位置を更新します。 |
IDiaEnumSymbolsByAddr2::PrevEx |
アドレス順に、前のシンボルを取得します。 取り込まれた要素の数だけ列挙子の位置を更新します。 |
解説
このインターフェイスは、アドレスによってグループ化されたシンボルを提供します。 SymTagUDT
(ユーザー定義型) やSymTagBaseClass
など、種類別にグループ化されたシンボルを操作するには、IDiaEnumSymbols
インターフェイスを使用します。
発信者向けのメモ
このインターフェイスを取得するには、IDiaSession::getSymbolsByAddr
メソッドを呼び出し、riid
パラメーターを IID_IDiaEnumSymbolsByAddr2
に設定してIUnknown::QueryInterface
を呼び出します。
例
この関数は、すべてのシンボルの名前とアドレスを相対仮想アドレス順に表示します。
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 );
}
}
要件
ヘッダー: Dia2.h
ライブラリ: diaguids.lib
DLL: msdia140.dll