
VC++2005MFC
typedef struct TMago{
stTestData mdata1[1000];
}stMago;
typedef struct TKo{
stTestData kdata1[10000];
stTestData kdata2[10000];
stTestData kdata3[10000];
stTestData kdata4[10000];
stTestData kdata5[10000];
stMago *pMago[10000];
}stKo;
typedef struct TOya{
stTestData odata1[100];
stTestData odata2[100];
stKo *pKo[100];
}stOya;
stOya m_stOya;//メンバ変数
という構造体が定義されているのですが、
【Q1】
pMago、pKoのそれぞれ指定した分のメモリ確保は
例)それぞれ10個と20個分メモリ確保したい場合
for(int i = 0; i < 10; i++)
{
m_stOya.pKo[i] = new TOya;
}
とした後、
for(int i = 0; i < 10;i++)
{
for(int j = 0; j < 20; j++)
{
m_stOya.pKo[i]->pMago[j] = new TMago;
}
}
で良いでしょうか?
【Q2】
また、これを解放するには、
同じループ処理を今度は内側から
for(int i = 0; i < 10;i++)
{
for(int j = 0; j < 20; j++)
{
Delete m_stOya.pKo[i]->pMago[j];
}
}
for(int i = 0; i < 10; i++)
{
Delete m_stOya.pKo[i];
}
で良いでしょうか?
【Q3】
pMago[0]の内容をpMago[1]へコピーしたい場合は
memcpy(m_stOya.pKo[0]->pMago[1], m_stOya.pKo[0]->pMago[0], sizeof(TMago));
で良いでしょうか?
使い方なんてCの基本だろーですとか、そもそもこんな作りの構造体やめれば?
と思われることは重々承知ですが、ご教授お願いいたしますm(__)m
A 回答 (5件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
本題は終わってるようなものなので関係ない部分だけ:
1.
C++ なら, 構造体に対して typedef する必然性はあんまりないと思います. 構造体のタグ名が (曖昧でなければ) そのまま型名として使えますし. C でも, タグ名と同じ名前に typedef すれば実質的に C++ と同じような使い方ができます (が, C で「タグ名と同じ名前に typedef できる」ことを知らない人が見ると文句を言いだすかもしれん).
2.
構造体をコピーするのに memcpy する必然性は (C でも C++ でも) 全くありません. memcpy では deep copy できないので shallow copy を想定しているはずですが, それなら単純に = でいい. 特に今の場合 memcpy すると危険な状態になりえます.
3.
#2 でも言われている (し自ら突っ込んでる) けど構造体のつくりがおかしい. せめて std::vector くらいは使ってほしい.
4.
そもそもどこが MFC?
No.4
- 回答日時:
あっ! 逆だ。
> m_stOya.pKo[0]->pMago[0] = m_stOya.pKo[0]->pMago[1];
m_stOya.pKo[0]->pMago[1] = m_stOya.pKo[0]->pMago[0];
No.3
- 回答日時:
【Q1】
> m_stOya.pKo[i] = new TOya;
m_stOya.pKo[i] = new TKo;
だろう。
for(int i = 0; i < 10;i++)
{
m_stOya.pKo[i] = new TKo;
for(int j = 0; j < 20; j++)
{
m_stOya.pKo[i]->pMago[j] = new TMago;
}
}
とすればいい。
【Q2】
for(int i = 0; i < 10;i++)
{
for(int j = 0; j < 20; j++)
{
delete m_stOya.pKo[i]->pMago[j];
}
delete m_stOya.pKo[i];
}
【Q3】
NG
m_stOya.pKo[0]->pMago[0] = m_stOya.pKo[0]->pMago[1];
とする。
No.2
- 回答日時:
Cなら new 演算子も delete 演算子も無いのが「基本」なので,Q1,Q2は間違い。
malloc,callocで確保してfreeで解放するのが基本。C++なら、Q1は「間違いではない」。
Q2はDeleteという演算子は標準には無いので間違い。deleteなら、Q1との組合せなら「間違いではない」
Q3は「間違いとは言いきれないが、stTestDataの定義によっては問題が起こる場合がある」
詳細は「浅いコピー」「深いコピー」で検索。memcpyでは浅いコピーになります。
また、(C++でoperator =を定義してなければ)単に *(m_stOya.pKo[0]->pMago[1]) = *(m_stOya.pKo[0]->pMago[0]) でもいいはず。
ただ、御自身でおっしゃるように
> そもそもこんな作りの構造体やめれば?
と思いますよ。
「10個確保」とかいうのを見ると、
odata1が100個、 odata2が100個、 *pKOが100個
がワンセット、というよりは
{odata1、odata2、*pKO}のセットが100個(または必要な数)
という感じではないですか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
最早開始時間と最遅完了時刻を...
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語での奇数の和
-
Haskellで関数を合成しようとす...
-
式は定数値が必要です」という...
-
C言語での引数の省略方法
-
未解決の外部シンボル _printf...
-
CStringの配列要素を関数で受け...
-
「指定されたキャストは有効で...
-
return 1L
-
複数桁10進数の*桁目だけを抽出...
-
任意の文字列のアルファベット...
-
入力された数字を大きい順に並...
-
C言語のプログラム作成について
-
【C++】行列データの読み込み
-
2次元配列とポインタの引数受け...
-
数字列を3桁ごとにカンマで区切...
-
C言語 配列と関数の練習問題
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
#define _CRT_SECURE_NO_WARNIN...
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
複数桁10進数の*桁目だけを抽出...
-
return 1L
-
if と配列の組み合わせ
-
ラップ関数とはどんなものですか?
-
式は定数値が必要です」という...
-
数字列を3桁ごとにカンマで区切...
-
実数の整数部,小数部の取得
-
C言語でDxlibを使って3x3の奇数...
-
プログラムについて(UNIX)
-
acceptをalarmでタイムアウトさ...
-
C言語の課題です
-
エラー 添字が付けられた値が、...
-
CStringの配列要素を関数で受け...
-
最早開始時間と最遅完了時刻を...
-
入力された数字を大きい順に並...
おすすめ情報