次の方法で共有


COleSafeArray::Create

配列データの割り当て、初期化します。

void Create(
   VARTYPE vtSrc,
   DWORD dwDims,
   DWORD* rgElements 
);
void Create(
   VARTYPE vtSrc,
   DWORD dwDims,
   SAFEARRAYBOUND* rgsabounds 
);

パラメーター

  • vtSrc
    配列 (つまり、配列の各要素に VARTYPE ) の基本型。VARTYPE、異なる型のサブセットに限定されます。VT_ARRAYVT_BYREF のフラグは配置できません。VT_EMPTYVT_NULL は、配列に対して無効な基本データ型です。他の型はすべて有効です。

  • dwDims
    配列の次元数。これは、配列は Redimと作成後に変更できます。

  • rgElements
    配列の各次元の要素数の配列へのポインター。

  • rgsabounds
    配列に代入する制限 (各次元の 1) のベクターへのポインター。

解説

この関数は、現在の配列のデータを必要に応じて削除します。エラーの場合、関数は CMemoryExceptionをスローします。

使用例

COleSafeArray saMatrix;
DWORD numElements[] = {10, 5};

// creates a 2 dimensional safearray of type VT_I2 
// with size 10x5 elements, with all indices starting at 0(default)
saMatrix.Create(VT_I2, 2, numElements);

ASSERT(saMatrix.GetDim() == 2);

COleSafeArray saVector;
SAFEARRAYBOUND rgsabounds[] = { {5, 2} };

// creates a 1 dimensional safearray of type VT_I1 
// with size 5 elements, with the index starting at 2
saVector.Create(VT_I1, 1, rgsabounds);

ASSERT(saVector.GetDim() == 1);

必要条件

ヘッダー : afxdisp.h

参照

関連項目

COleSafeArray クラス

階層図

SafeArrayCreate