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