Udostępnij za pośrednictwem


IDiaEnumFrameData

Wylicza różne elementy danych ramek zawarte w źródle danych.

Składnia

IDiaEnumFrameData : IUnknown

Metody w tabeli Vtable Order

W poniższej tabeli przedstawiono metody .IDiaEnumFrameData

Metoda opis
IDiaEnumFrameData::get__NewEnum IEnumVARIANT Interface Pobiera wersję tego modułu wyliczającego.
IDiaEnumFrameData::get_Count Pobiera liczbę elementów danych ramek.
IDiaEnumFrameData::Item Pobiera element danych ramki za pomocą indeksu.
IDiaEnumFrameData::Next Pobiera określoną liczbę elementów danych ramek w sekwencji wyliczenia.
IDiaEnumFrameData::Skip Pomija określoną liczbę elementów danych ramek w sekwencji wyliczenia.
IDiaEnumFrameData::Reset Resetuje sekwencję wyliczenia na początku.
IDiaEnumFrameData::Clone Tworzy moduł wyliczający, który zawiera ten sam stan wyliczenia co bieżący moduł wyliczający.
IDiaEnumFrameData::frameByRVA Zwraca ramkę według względnego adresu wirtualnego (RVA).
IDiaEnumFrameData::frameByVA Zwraca ramkę według adresu wirtualnego (VA).

Uwagi

Uwagi dotyczące wywoływania

Uzyskaj ten interfejs z metody IDiaSession::getEnumTables . Zobacz przykład, aby uzyskać szczegółowe informacje.

Przykład

W tym przykładzie pokazano, jak uzyskać ( GetEnumFrameData funkcję) i użyć ( ShowFrameData funkcji) interfejsu IDiaEnumFrameData . Zobacz interfejs IDiaFrameData, aby zapoznać się z PrintFrameData przykładem funkcji.


      IDiaEnumFrameData* GetEnumFrameData(IDiaSession *pSession)
{
    IDiaEnumFrameData* pUnknown    = NULL;
    REFIID             iid         = __uuidof(IDiaEnumFrameData);
    IDiaEnumTables*    pEnumTables = NULL;
    IDiaTable*         pTable      = NULL;
    ULONG              celt        = 0;

    if (pSession->getEnumTables(&pEnumTables) != S_OK)
    {
        wprintf(L"ERROR - GetTable() getEnumTables\n");
        return NULL;
    }
    while (pEnumTables->Next(1, &pTable, &celt) == S_OK && celt == 1)
    {
        // There is only one table that matches the given iid
        HRESULT hr = pTable->QueryInterface(iid, (void**)&pUnknown);
        pTable->Release();
        if (hr == S_OK)
        {
            break;
        }
    }
    pEnumTables->Release();
    return pUnknown;
}

void ShowFrameData(IDiaSession *pSession)
{
    IDiaEnumFrameData* pEnumFrameData = GetEnumFrameData(pSession);

    if (pEnumFrameData != NULL)
    {
        IDiaFrameData* pFrameData;
        ULONG celt = 0;

        while(pEnumFrameData->Next(1, &pFrameData, &celt) == S_OK &&
              celt == 1)
        {
            PrintFrameData(pFrameData);
            pFrameData->Release();
        }
        pEnumFrameData->Release();
    }
}

Wymagania

Nagłówek: Dia2.h

Biblioteka: diaguids.lib

BIBLIOTEKA DLL: msdia80.dll

Zobacz też