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