Condividi tramite


Classe CComSafeArray

Questa classe è un wrapper per la SAFEARRAY struttura.

Sintassi

template <typename T, VARTYPE _vartype = _ATL_AutomationType<T>::type>
class CComSafeArray

Parametri

T
Tipo di dati da memorizzare nella matrice.

Membri

Costruttori pubblici

Nome Descrizione
CComSafeArray::CComSafeArray Costruttore.
CComSafeArray::~CComSafeArray Distruttore.

Metodi pubblici

Nome Descrizione
CComSafeArray::Add Aggiunge uno o più elementi, o una SAFEARRAY struttura, a un oggetto CComSafeArray.
CComSafeArray::Attach Associa una SAFEARRAY struttura a un CComSafeArray oggetto .
CComSafeArray::CopyFrom Copia il contenuto di una SAFEARRAY struttura nell'oggetto CComSafeArray .
CComSafeArray::CopyTo Crea una copia dell'oggetto CComSafeArray.
CComSafeArray::Create Crea un oggetto CComSafeArray.
CComSafeArray::Destroy Elimina un oggetto CComSafeArray .
CComSafeArray::Detach Scollega un oggetto SAFEARRAY da un CComSafeArray oggetto .
CComSafeArray::GetAt Recupera un singolo elemento da una matrice unidimensionale.
CComSafeArray::GetCount Restituisce il numero di elementi nella matrice.
CComSafeArray::GetDimensions Restituisce il numero di dimensioni nella matrice.
CComSafeArray::GetLowerBound Restituisce il limite inferiore di una determinata dimensione della matrice.
CComSafeArray::GetSafeArrayPtr Restituisce l'indirizzo del membro dati m_psa .
CComSafeArray::GetType Restituisce il tipo di dati memorizzati nella matrice.
CComSafeArray::GetUpperBound Restituisce il limite superiore di una determinata dimensione della matrice.
CComSafeArray::IsSizable Verifica se è possibile ridimensionare un oggetto CComSafeArray .
CComSafeArray::MultiDimGetAt Recupera un singolo elemento da una matrice multidimensionale.
CComSafeArray::MultiDimSetAt Imposta il valore di un elemento in una matrice multidimensionale.
CComSafeArray::Resize Ridimensiona un oggetto CComSafeArray .
CComSafeArray::SetAt Imposta il valore di un elemento in una matrice unidimensionale.

Operatori pubblici

Nome Descrizione
CComSafeArray::operator LPSAFEARRAY Esegue il cast di un valore a un SAFEARRAY puntatore.
CComSafeArray::operator[] Recupera un elemento da una matrice.
CComSafeArray::operator = Operatore di assegnazione.

Membri dati pubblici

Nome Descrizione
CComSafeArray::m_psa Questo membro dati contiene l'indirizzo della SAFEARRAY struttura.

Osservazioni:

CComSafeArray fornisce un wrapper per la SAFEARRAY classe del tipo di dati, semplificando la creazione e la gestione di matrici singole e multidimensionali di quasi tutti i tipi supportati VARIANT .

CComSafeArray semplifica il passaggio delle matrici tra processi e fornisce anche protezione aggiuntiva poiché controlla i valori degli indici della matrice rispetto ai limiti superiore e inferiore.

Il limite inferiore di una classe CComSafeArray può iniziare con qualsiasi valore definito dall'utente; tuttavia, le matrici a cui si accede con C++ usano un limite inferiore pari a 0. Altri linguaggi, quali Visual Basic, possono usare altri valori di delimitazione (ad esempio da -10 a 10).

Usare CComSafeArray::Create per creare un CComSafeArray oggetto e CComSafeArray::Destroy per eliminarlo.

Un CComSafeArray oggetto può contenere il sottoinsieme di tipi di VARIANT dati seguente:

VARTYPE Descrizione
VT_I1 char
VT_I2 short
VT_I4 int
VT_I4 long
VT_I8 longlong
VT_UI1 byte
VT_UI2 ushort
VT_UI4 uint
VT_UI4 ulong
VT_UI8 ulonglong
VT_R4 float
VT_R8 double
VT_DECIMAL Puntatore decimale
VT_VARIANT Puntatore Variant
VT_CY Currency (tipo di dati)

Requisiti

Intestazione: atlsafe.h

Esempio

// Create a multidimensional array, 
// then write and read elements

// Define an array of character pointers
CComSafeArray<char> *pSar;

char cElement;
char cTable[2][3] = {'A','B','C','D','E','F'};

// Declare the variable used to store the
// array indexes
LONG aIndex[2];

// Define the array bound structure
CComSafeArrayBound bound[2];
bound[0].SetCount(2);
bound[0].SetLowerBound(0);
bound[1].SetCount(3);
bound[1].SetLowerBound(0);   

// Create a new 2 dimensional array
// each dimension size is 3
pSar = new CComSafeArray<char>(bound,2); 

// Use MultiDimSetAt to store characters in the array
for (int x = 0; x < 2; x++)
{
   for (int y = 0; y < 3; y++)
   {
      aIndex[0] = x;
      aIndex[1] = y;
      HRESULT hr = pSar->MultiDimSetAt(aIndex,cTable[x][y]);
      ATLASSERT(hr == S_OK);
   }
}
// Use MultiDimGetAt to retrieve characters in the array
for (int x = 0; x < 2; x++)
{
   for (int y = 0; y < 3; y++)
   {
      aIndex[0]=x;
      aIndex[1]=y;
      HRESULT hr = pSar->MultiDimGetAt(aIndex,cElement);
      ATLASSERT(hr == S_OK);
      ATLASSERT(cElement == cTable[x][y]);
   }   
}

CComSafeArray::Add

Aggiunge uno o più elementi, o una SAFEARRAY struttura, a un oggetto CComSafeArray.

HRESULT Add(const SAFEARRAY* psaSrc);
HRESULT Add(ULONG ulCount, const T* pT, BOOL bCopy = TRUE);
HRESULT Add(const T& t, BOOL bCopy = TRUE);

Parametri

psaSrc
Puntatore a un oggetto SAFEARRAY.

ulCount
Numero di oggetti da aggiungere alla matrice.

pT
Puntatore a uno o più oggetti da aggiungere alla matrice.

t
Riferimento all'oggetto da aggiungere alla matrice.

bCopy
Indica se deve essere creata una copia dei dati. Il valore predefinito è TRUE.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

I nuovi oggetti vengono accodati alla fine dell'oggetto esistente SAFEARRAY . L'aggiunta di un oggetto a un oggetto multidimensionale SAFEARRAY non è supportata. Quando si aggiunge una matrice di oggetti esistente, entrambe le matrici devono contenere elementi dello stesso tipo.

Il bCopy flag viene preso in considerazione quando gli elementi di tipo BSTR o VARIANT vengono aggiunti a una matrice. Il valore predefinito di TRUE garantisce che venga creata una nuova copia dei dati quando l'elemento viene aggiunto alla matrice.

CComSafeArray::Attach

Associa una SAFEARRAY struttura a un CComSafeArray oggetto .

HRESULT Attach(const SAFEARRAY* psaSrc);

Parametri

psaSrc
Puntatore alla SAFEARRAY struttura.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Associa una SAFEARRAY struttura a un CComSafeArray oggetto, rendendo disponibili i metodi esistenti CComSafeArray .

CComSafeArray::CComSafeArray

Costruttore.

CComSafeArray();
CComSafeArray(const SAFEARRAYBOUND& bound);
CComSafeArray(ULONG  ulCount, LONG lLBound = 0);
CComSafeArray(const SAFEARRAYBOUND* pBound, UINT uDims = 1);
CComSafeArray(const CComSafeArray& saSrc);
CComSafeArray(const SAFEARRAY& saSrc);
CComSafeArray(const SAFEARRAY* psaSrc);

Parametri

bound
Struttura SAFEARRAYBOUND.

ulCount
Numero di elementi nella matrice.

lLBound
Valore limite inferiore; ovvero l'indice del primo elemento nella matrice.

pBound
Puntatore a una SAFEARRAYBOUND struttura.

uDims
Conteggio delle dimensioni nella matrice.

saSrc
Riferimento a una struttura o CComSafeArray a un SAFEARRAY oggetto . In entrambi i casi, il costruttore usa questo riferimento per creare una copia della matrice, quindi la matrice non viene fatto riferimento dopo la costruzione.

psaSrc
Puntatore a una SAFEARRAY struttura. Il costruttore usa questo indirizzo per creare una copia della matrice, quindi la matrice non viene mai fatto riferimento dopo la costruzione.

Osservazioni:

Crea un oggetto CComSafeArray.

CComSafeArray::~CComSafeArray

Distruttore.

~CComSafeArray() throw()

Osservazioni:

Libera tutte le risorse allocate.

CComSafeArray::CopyFrom

Copia il contenuto di una SAFEARRAY struttura nell'oggetto CComSafeArray .

HRESULT CopyFrom(LPSAFEARRAY* ppArray);

Parametri

ppArray
Puntatore all'oggetto SAFEARRAY da copiare.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Questo metodo copia il contenuto di un SAFEARRAY oggetto nell'oggetto corrente CComSafeArray . Il contenuto esistente della matrice viene sostituito.

CComSafeArray::CopyTo

Crea una copia dell'oggetto CComSafeArray.

HRESULT CopyTo(LPSAFEARRAY* ppArray);

Parametri

ppArray
Puntatore a una posizione in cui creare il nuovo SAFEARRAYoggetto .

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Questo metodo copia il contenuto di un CComSafeArray oggetto in una SAFEARRAY struttura.

CComSafeArray::Create

Crea un oggetto CComSafeArray.

HRESULT Create(const SAFEARRAYBOUND* pBound, UINT uDims = 1);
HRESULT Create(ULONG ulCount = 0, LONG lLBound = 0);

Parametri

pBound
Puntatore a un oggetto SAFEARRAYBOUND.

uDims
Numero di dimensioni nella matrice.

ulCount
Numero di elementi nella matrice.

lLBound
Valore limite inferiore; ovvero l'indice del primo elemento nella matrice.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Un CComSafeArray oggetto può essere creato da una struttura esistente SAFEARRAYBOUND e dal numero di dimensioni oppure specificando il numero di elementi nella matrice e il limite inferiore. Se è necessario accedere alla matrice da C++, il limite inferiore deve essere 0. Altri linguaggi possono consentire altri valori per il limite inferiore, ad esempio Visual Basic supporta matrici con elementi con un intervallo compreso tra -10 e 10.

CComSafeArray::Destroy

Elimina un oggetto CComSafeArray .

HRESULT Destroy();

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Elimina definitivamente un oggetto esistente CComSafeArray e tutti i dati contenuti.

CComSafeArray::Detach

Scollega un oggetto SAFEARRAY da un CComSafeArray oggetto .

LPSAFEARRAY Detach();

Valore restituito

Restituisce un puntatore a un SAFEARRAY oggetto .

Osservazioni:

Questo metodo scollega l'oggetto SAFEARRAY dall'oggetto CComSafeArray .

CComSafeArray::GetAt

Recupera un singolo elemento da una matrice unidimensionale.

T& GetAt(LONG lIndex) const;

Parametri

lIndex
Numero di indice del valore nella matrice da restituire.

Valore restituito

Restituisce un riferimento all'elemento della matrice richiesto.

CComSafeArray::GetCount

Restituisce il numero di elementi nella matrice.

ULONG GetCount(UINT uDim = 0) const;

Parametri

uDim
Dimensione della matrice.

Valore restituito

Restituisce il numero di elementi nella matrice.

Osservazioni:

Se utilizzato con una matrice multidimensionale, questo metodo restituirà solo il numero di elementi in una dimensione specifica.

CComSafeArray::GetDimensions

Restituisce il numero di dimensioni nella matrice.

UINT GetDimensions() const;

Valore restituito

Restituisce il numero di dimensioni nella matrice.

CComSafeArray::GetLowerBound

Restituisce il limite inferiore di una determinata dimensione della matrice.

LONG GetLowerBound(UINT uDim = 0) const;

Parametri

uDim
Dimensione della matrice per la quale ottenere il limite inferiore. Se omesso, il valore predefinito è 0.

Valore restituito

Restituisce il limite inferiore.

Osservazioni:

Se il limite inferiore è 0, indica una matrice simile a C il cui primo elemento è il numero di elemento 0. In caso di errore, ad esempio, un argomento di dimensione non valido, questo metodo chiama AtlThrow con un oggetto HRESULT che descrive l'errore.

CComSafeArray::GetSafeArrayPtr

Restituisce l'indirizzo del membro dati m_psa .

LPSAFEARRAY* GetSafeArrayPtr() throw();

Valore restituito

Restituisce un puntatore al CComSafeArray::m_psa membro dati.

CComSafeArray::GetType

Restituisce il tipo di dati memorizzati nella matrice.

VARTYPE GetType() const;

Valore restituito

Restituisce il tipo di dati archiviati nella matrice, che può essere uno dei tipi seguenti:

VARTYPE Descrizione
VT_I1 char
VT_I2 short
VT_I4 int
VT_I4 long
VT_I8 longlong
VT_UI1 byte
VT_UI2 ushort
VT_UI4 uint
VT_UI4 ulong
VT_UI8 ulonglong
VT_R4 float
VT_R8 double
VT_DECIMAL Puntatore decimale
VT_VARIANT Puntatore Variant
VT_CY Currency (tipo di dati)

CComSafeArray::GetUpperBound

Restituisce il limite superiore di una determinata dimensione della matrice.

LONG GetUpperBound(UINT uDim = 0) const;

Parametri

uDim
Dimensione della matrice per la quale ottenere il limite superiore. Se omesso, il valore predefinito è 0.

Valore restituito

Restituisce il limite superiore. Questo valore è inclusivo, ovvero l'indice massimo valido per questa dimensione.

Osservazioni:

In caso di errore, ad esempio, un argomento di dimensione non valido, questo metodo chiama AtlThrow con un oggetto HRESULT che descrive l'errore.

CComSafeArray::IsSizable

Verifica se è possibile ridimensionare un oggetto CComSafeArray .

bool IsSizable() const;

Valore restituito

Restituisce TRUE se l'oggetto CComSafeArray può essere ridimensionato, FALSE se non è possibile.

CComSafeArray::m_psa

Contiene l'indirizzo della SAFEARRAY struttura a cui si accede.

LPSAFEARRAY m_psa;

CComSafeArray::MultiDimGetAt

Recupera un singolo elemento da una matrice multidimensionale.

HRESULT MultiDimGetAt(const LONG* alIndex, T& t);

Parametri

alIndex
Puntatore a un vettore di indici per ogni dimensione nella matrice. La dimensione più a sinistra (più significativa) è alIndex[0].

t
Riferimento ai dati restituiti.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

CComSafeArray::MultiDimSetAt

Imposta il valore di un elemento in una matrice multidimensionale.

HRESULT MultiDimSetAt(const LONG* alIndex, const T& t);

Parametri

alIndex
Puntatore a un vettore di indici per ogni dimensione nella matrice. La dimensione più a destra (meno significativa) è alIndex[0].

T
Specifica il valore del nuovo elemento.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Si tratta di una versione multidimensionale di CComSafeArray::SetAt.

CComSafeArray::operator []

Recupera un elemento da una matrice.

T& operator[](long lindex) const;
T& operator[](int nindex) const;

Parametri

lIndex, nIndex
Numero di indice dell'elemento obbligatorio nella matrice.

Valore restituito

Restituisce l'elemento di matrice appropriato.

Osservazioni:

Esegue una funzione simile a CComSafeArray::GetAt, ma questo operatore funziona solo con matrici unidimensionali.

CComSafeArray::operator =

Operatore di assegnazione.

ATL::CComSafeArray<T>& operator=(const ATL::CComSafeArray& saSrc);
ATL::CComSafeArray<T>& operator=(const SAFEARRAY* psaSrc);

Parametri

saSrc
Riferimento a un oggetto CComSafeArray.

psaSrc
Puntatore a un oggetto SAFEARRAY.

Valore restituito

Restituisce il tipo di dati memorizzati nella matrice.

CComSafeArray::operator LPSAFEARRAY

Esegue il cast di un valore a un SAFEARRAY puntatore.

operator LPSAFEARRAY() const;

Valore restituito

Esegue il cast di un valore a un SAFEARRAY puntatore.

CComSafeArray::Resize

Ridimensiona un oggetto CComSafeArray .

HRESULT Resize(const SAFEARRAYBOUND* pBound);
HRESULT Resize(ULONG ulCount, LONG lLBound = 0);

Parametri

pBound
Puntatore a una SAFEARRAYBOUND struttura che contiene informazioni sul numero di elementi e sul limite inferiore di una matrice.

ulCount
Numero richiesto di oggetti nella matrice ridimensionata.

lLBound
Limite inferiore.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Questo metodo ridimensiona solo la dimensione più a destra. Non ridimensiona le matrici che restituiscono IsResizable come FALSE.

CComSafeArray::SetAt

Imposta il valore di un elemento in una matrice unidimensionale.

HRESULT SetAt(LONG lIndex, const T& t, BOOL bCopy = TRUE);

Parametri

lIndex
Numero di indice dell'elemento della matrice da impostare.

t
Nuovo valore dell'elemento specificato.

bCopy
Indica se deve essere creata una copia dei dati. Il valore predefinito è TRUE.

Valore restituito

Restituisce S_OK l'esito positivo o un errore in caso di errore HRESULT .

Osservazioni:

Il bCopy flag viene preso in considerazione quando gli elementi di tipo BSTR o VARIANT vengono aggiunti a una matrice. Il valore predefinito di TRUE garantisce che venga creata una nuova copia dei dati quando l'elemento viene aggiunto alla matrice.

Vedi anche

SAFEARRAY Tipo di dati
CComSafeArray::Create
CComSafeArray::Destroy
Cenni preliminari sulla classe