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