Udostępnij za pośrednictwem


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

Zobacz też