###環境
Windows10 64bit / Visual Studio 2019
C++17
###知りたいこと
以下のプログラムについて、メモリリークは発生しないでしょうか。
※値が格納されない変数については、コメントの通りの値が格納されていると仮定して下さい。
C++
1int main() { 2 std::vector<std::vector<CComVariant>> vec; 3 4 { 5 CComDispatchDriver disp; //エクセルの Range の IDispatch。 6 DISPID dispid; // Range.Value の DISPID。 7 CComVariant res; 8 HRESULT hr = disp->Invoke(dispid, IID_NULL, LOCALE_SYSTEM_DEFAULT, DISPATCH_METHOD, nullptr, &res, nullptr, nullptr); 9 10 CComSafeArray<VARIANT> source = res.parray; 11 12 int cnt1; // source の一次元の要素数。 13 int cnt2; // source の二次元の要素数。 14 vec.resize(cnt1, std::vector<CComVariant>(cnt2)); 15 16 // source の各次元の最小インデックスは必ず 0 とします。 17 for (int i = 0; i < cnt1; ++i) { 18 for (int j = 0; j < cnt2; ++j) { 19 LONG indices[2] = { i,j }; 20 source.MultiDimGetAt(indices, vec[i][j]); 21 } 22 } 23 } 24}
###懸念
当初、配列 source を CComSafeArray<CComVariant> 型の配列にする予定でした。
しかし、CComSafeArray の以下仕様上、CComVariant からは VARTYPE が取得できない様でコンパイルエラーとなってしまいます。
C++
1template <typename T, VARTYPE _vartype = _ATL_AutomationType<T>::type> 2class CComSafeArray
一番最後にスコープを抜けるのが std::vector<CComVariant> の配列である為、
スコープを抜ける際に CComVariant のディストラクタで後始末をしてくれるのではと考えていますが、自信がありません。
回答1件
あなたの回答
tips
プレビュー