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 接口。 有关 PrintFrameData 函数的示例,请参阅 IDiaFrameData 接口。


      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

另请参阅