IDiaSegment
Dane mapy z numer sekcji do segmentów w przestrzeni adresowej.
IDiaSegment : IUnknown
Metody w kolejności Vtable
W poniższej tabeli przedstawiono metody IDiaSegment.
Metoda |
Opis |
---|---|
Pobiera numer segmentu. |
|
Pobiera przesunięcie w segmentach, gdzie rozpoczyna się w sekcji. |
|
Pobiera liczbę bajtów w segmencie. |
|
Pobiera flagę wskazującą, czy segment można odczytać. |
|
Pobiera flagę wskazującą, czy segment można modyfikować. |
|
Pobiera flagę wskazującą, czy segment jest wykonywalny. |
|
Pobiera numer sekcji, która mapuje do tego segmentu. |
|
Pobiera względny adres wirtualny (RVA) Początek sekcji. |
|
Pobiera adres wirtualny (VA) Początek sekcji. |
Uwagi
Ponieważ DIA SDK już wykonuje tłumaczenia z przesunięciem sekcji względnych adresów wirtualnych, większość aplikacji nie spowoduje, że wykorzystanie informacji w mapie segmentu.
Uwagi do wywoływania
Ten interfejs uzyskać, wywołując IDiaEnumSegments::Item lub IDiaEnumSegments::Next metody.Zobacz przykład, aby uzyskać szczegółowe informacje.
Przykład
Funkcja ta wyświetla adres wszystkich segmentów w tabeli i dokładnością symbol.
void ShowSegments(IDiaTable *pTable, IDiaSession *pSession)
{
CComPtr<IDiaEnumSegments> pSegments;
if ( SUCCEEDED( pTable->QueryInterface(
_uuidof( IDiaEnumSegments ),
(void**)&pSegments )
)
)
{
CComPtr<IDiaSegment> pSegment;
while ( SUCCEEDED( hr = pSegments->Next( 1, &pSegment, &celt ) ) &&
celt == 1 )
{
DWORD rva;
DWORD seg;
pSegment->get_addressSection( &seg );
if ( pSegment->get_relativeVirtualAddress( &rva ) == S_OK )
{
printf( "Segment %i addr: 0x%.8X\n", seg, rva );
pSegment = NULL;
CComPtr<IDiaSymbol> pSym;
if ( psession->findSymbolByRVA( rva, SymTagNull, &pSym ) == S_OK )
{
CDiaBSTR name;
DWORD tag;
pSym->get_symTag( &tag );
pSym->get_name( &name );
printf( "\tClosest symbol: %ws (%ws)\n",
name != NULL ? name : L"",
szTags[ tag ] );
}
}
}
}
}
Wymagania
Nagłówek: Dia2.h
Biblioteki: diaguids.lib
Biblioteka DLL: msdia80.dll