Поделиться через


IDiaEnumFrameData

Перечисляет различные элементы данных кадра, содержащихся в источнике данных.

IDiaEnumFrameData : IUnknown

Методы в том порядке Vtable

В следующей таблице показаны методы IDiaEnumFrameData.

Метод

Описание

IDiaEnumFrameData::get__NewEnum

Извлекает IEnumVARIANT Interface версия данного перечислителя.

IDiaEnumFrameData::get_Count

Извлекает число элементов данных кадра.

IDiaEnumFrameData::Item

Получает элемент данных кадра посредством индекса.

IDiaEnumFrameData::Next

Получает заданное число элементов данных кадра в последовательности перечисления.

IDiaEnumFrameData::Skip

Пропустить заданное число элементов данных кадра в последовательности перечисления.

IDiaEnumFrameData::Reset

Сбросить последовательность перечисления в начало.

IDiaEnumFrameData::Clone

Создает перечислитель с тем же состоянием перечисления, что и текущий перечислитель.

IDiaEnumFrameData::frameByRVA

Возвращает кадр является относительным виртуальным адресом (RVA).

IDiaEnumFrameData::frameByVA

Возвращает кадр является виртуальным адресом (VA).

Заметки

Замечания для вызывающих объектов

Для получения этого интерфейса из IDiaSession::getEnumTables метод. См. пример.

Пример

В этом примере показано, как получить ( GetEnumFrameData (функция) и использует ShowFrameData функция) IDiaEnumFrameData интерфейс. См. IDiaFrameData интерфейс пример PrintFrameData функция.

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(); 
    }
}

Требования

заголовок: Dia2.h

Библиотеки: diaguids.lib

Библиотеки DLL: msdia80.dll

См. также

Ссылки

IDiaSession::getEnumTables

IDiaFrameData

Другие ресурсы

Интерфейсы (SDK для доступа к интерфейсу отладки)