次の方法で共有


COleSafeArray::CreateOneDim

1 次元の COleSafeArray 新しいオブジェクトを作成します。

void CreateOneDim(
   VARTYPE vtSrc,
   DWORD dwElements,
   const void* pvSrcData = NULL,
   long nLBound = 0 
);

パラメーター

  • vtSrc
    配列 (つまり、配列の各要素に VARTYPE ) の基本型。

  • dwElements
    配列の要素数。これは、配列は ResizeOneDimと作成後に変更できます。

  • pvSrcData
    配列にコピーされるデータへのポインター。

  • nLBound
    配列の下限。

解説

関数は、ポインターが nullである pvSrcData 指定したデータをコピーする配列のデータの割り当て、初期化します。

エラーの場合、関数は CMemoryExceptionをスローします。

使用例

VARIANT varColInfo[3];

//initialize VARIANTs
for (int i = 0; i < 3; i++)
   VariantInit(&varColInfo[i]);

// Column Name
varColInfo[0].vt = VT_BSTR;
varColInfo[0].bstrVal = ::SysAllocString(L"Name");

// Column Type
varColInfo[1].vt = VT_UI4;
varColInfo[1].lVal = 1;

COleSafeArray sa;
//create a 1 dimensional safearray of VARIANTs
//& initialize it with varColInfo VARIANT array
sa.CreateOneDim(VT_VARIANT, 2, varColInfo);

//check that the dimension is 2
ASSERT(sa.GetOneDimSize() == 2);

//increase safearray size by 1
sa.ResizeOneDim(3);

// populate the last element of the safearray, (Column Size)
varColInfo[2].vt = VT_I4;
varColInfo[2].lVal = 30;
long el = 2;
sa.PutElement(&el, &varColInfo[2]);

必要条件

ヘッダー : afxdisp.h

参照

関連項目

COleSafeArray クラス

階層図

COleSafeArray::GetOneDimSize

COleSafeArray::ResizeOneDim

COleSafeArray::Create