IDiaImageData
Uwidacznia szczegóły lokalizacji podstawowej i przesunięcia pamięci modułu lub obrazu.
Składnia
IDiaImageData : IUnknown
Metody w tabeli Vtable Order
W poniższej tabeli przedstawiono metody .IDiaImageData
Metoda | opis |
---|---|
IDiaImageData::get_relativeVirtualAddress | Pobiera lokalizację w pamięci wirtualnej modułu względem aplikacji. |
IDiaImageData::get_virtualAddress | Pobiera lokalizację w pamięci wirtualnej obrazu. |
IDiaImageData::get_imageBase | Pobiera lokalizację pamięci, w której ma być oparty obraz. |
Uwagi
Niektóre strumienie debugowania (XDATA, PDATA) zawierają również kopie danych przechowywanych na obrazie. Te obiekty danych strumienia mogą być odpytywane dla interfejsu IDiaImageData
. Aby uzyskać szczegółowe informacje, zobacz sekcję "Uwagi dla osób wywołujących".
Uwagi dotyczące wywoływania
Uzyskaj ten interfejs, wywołując QueryInterface
obiekt IDiaEnumDebugStreamData . Pamiętaj, że nie wszystkie strumienie debugowania obsługują IDiaImageData
interfejs. Na przykład obecnie tylko strumienie XDATA i PDATA obsługują IDiaImageData
interfejs.
Przykład
W tym przykładzie przeszukuje wszystkie strumienie debugowania dla dowolnego strumienia obsługującego IDiaImageData
interfejs. Jeśli taki strumień zostanie znaleziony, zostaną wyświetlone pewne informacje o tym strumieniu.
void ShowImageData(IDiaSession *pSession)
{
if (pSession != NULL)
{
CComPtr<IDiaEnumDebugStreams> pStreamsList;
HRESULT hr;
hr = pSession->getEnumDebugStreams(&pStreamsList);
if (SUCCEEDED(hr))
{
LONG numStreams = 0;
hr = pStreamsList->get_Count(&numStreams);
if (SUCCEEDED(hr))
{
ULONG fetched = 0;
for (LONG i = 0; i < numStreams; i++)
{
CComPtr<IDiaEnumDebugStreamData> pStream;
hr = pStreamsList->Next(1,&pStream,&fetched);
if (fetched == 1)
{
CComPtr<IDiaImageData> pImageData;
hr = pStream->QueryInterface(__uuidof(IDiaImageData),
(void **)&pImageData);
if (SUCCEEDED(hr))
{
CComBSTR name;
hr = pStream->get_name(&name);
if (SUCCEEDED(hr))
{
wprintf(L"Stream %s:\n",(BSTR)name);
}
else
{
wprintf(L"Failed to get name of stream\n");
}
ULONGLONG imageBase = 0;
if (pImageData->get_imageBase(&imageBase) == S_OK)
{
wprintf(L" image base = 0x%0I64x\n",imageBase);
}
DWORD relVA = 0;
if (pImageData->get_relativeVirtualAddress(&relVA) == S_OK)
{
wprintf(L" relative virtual address = 0x%08lx\n",relVA);
}
ULONGLONG va = 0;
if (pImageData->get_virtualAddress(&va) == S_OK)
{
wprintf(L" virtual address = 0x%0I64x\n", va);
}
}
}
}
}
}
}
}
Wymagania
Nagłówek: Dia2.h
Biblioteka: diaguids.lib
BIBLIOTEKA DLL: msdia80.dll