IDiaEnumFrameData
Wylicza różnych elementów danych ramki, zawarte w źródle danych.
IDiaEnumFrameData : IUnknown
Metody w kolejności Vtable
W poniższej tabeli przedstawiono metody IDiaEnumFrameData.
Metoda |
Opis |
---|---|
Pobiera IEnumVARIANT Interface wersji ten moduł wyliczający. |
|
Pobiera numer ramki elementów danych. |
|
Pobiera element danych ramkę z indeksu. |
|
Pobiera określoną liczbę elementów danych ramkę sekwencji wyliczania. |
|
Pomija określoną liczbę elementów danych ramkę sekwencji wyliczania. |
|
Resetuje sekwencji wyliczenie na początku. |
|
Tworzy moduł wyliczający zawierający tym samym stanie wyliczenie jako bieżący moduł wyliczający. |
|
Zwraca ramki przez względny adres wirtualny (RVA). |
|
Zwraca adres wirtualny (VA) ramki. |
Uwagi
Uwagi do wywoływania
Uzyskania tego interfejsu, z IDiaSession::getEnumTables metody.Zobacz przykład, aby uzyskać szczegółowe informacje.
Przykład
Ten przykład pokazuje sposób uzyskiwania ( GetEnumFrameData funkcja) i użyć ( ShowFrameData funkcja) IDiaEnumFrameData interfejsu.Zobacz IDiaFrameData interfejsu, na przykład PrintFrameData 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
Biblioteki: diaguids.lib
Biblioteka DLL: msdia80.dll