COleSafeArray::GetElement
Recupera um único elemento de matriz segura.
void GetElement(
long* rgIndices,
void* pvData
);
Parâmetros
rgIndices
Ponteiro para uma matriz de índices para cada dimensão da matriz.pvData
Ponteiro para o local para colocar o elemento da matriz.
Comentários
Esta função chama automaticamente o windows funções SafeArrayLock e SafeArrayUnlock antes e depois de recuperar o elemento. Se o elemento de dados for uma seqüência de caracteres, objeto ou variante, a função copia o elemento da maneira correta.O parâmetro pvData deve apontar para uma grande buffer suficiente para conter o elemento.
Em erro, a função lança um CMemoryException or COleException.
Exemplo
//sa is of type COleSafeArray with 2 dimensions
//Determine upper bounds for both dimensions
long lNumRows;
long lNumCols;
sa.GetUBound(1, &lNumRows);
sa.GetUBound(2, &lNumCols);
//Display the elements in the SAFEARRAY.
long index[2];
VARIANT val;
//Determine lower bounds for both dimensions
long lowRow, lowCol;
sa.GetLBound(1, &lowRow);
sa.GetLBound(2, &lowCol);
for(long r = lowRow; r <= lNumRows; r++ )
{
for(long c = lowCol; c <= lNumCols; c++ )
{
index[0] = r;
index[1] = c;
//retrieve each element of the safearray
sa.GetElement(index, &val);
switch(val.vt)
{
case VT_R8:
TRACE(_T("%1.2f\n"), val.dblVal);
break;
case VT_BSTR:
TRACE(_T("%s\n"),(CString)val.bstrVal);
break;
// other cases ommitted
case VT_EMPTY:
TRACE(_T("<empty>\n"));
break;
}
}
}
Requisitos
Cabeçalho: afxdisp.h