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.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個(または必要な数)
という感じではないですか?
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.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.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?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# プログラムが書けません。 4 2023/01/22 22:57
- C言語・C++・C# 変数のスコープ 5 2023/05/27 17:50
- C言語・C++・C# 未解決の外部シンボル _printfが関数_mainで参照されました 1 2022/09/18 15:28
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- C言語・C++・C# C 言語の Gauss Jordan 法について 2 2022/12/28 11:16
- C言語・C++・C# カードシャッフルのブログラムを使ってc言語でブラックジャックをしたい 2 2022/04/12 15:13
- 大学・短大 C言語線形リストの問題です 3 2022/12/22 00:45
- Java javaでのプログラム(配列)について質問です. 2 2022/10/14 22:27
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「指定されたキャストは有効で...
-
複数桁10進数の*桁目だけを抽出...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語での引数の省略方法
-
【C++】関数ポインタの使い方
-
比較回数と交換回数表示について
-
C言語で三目並べをするプログラ...
-
if と配列の組み合わせ
-
商と剰余を同時に求める(C言語)
-
C言語での奇数の和
-
ラップ関数とはどんなものですか?
-
Arduinoのプログラムにエラーが...
-
C言語
-
並列プログラミングのπ計算につ...
-
C言語 エラーの原因がわからな...
-
インライン展開されているか確...
-
GlobalAllocの変数を関数に引き...
-
HANDLEて何ですか?
-
read関数をノンブロッキングで...
-
C++でvectorにテキストファイル...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
「指定されたキャストは有効で...
-
C言語 配列と関数の練習問題
-
複数桁10進数の*桁目だけを抽出...
-
(int *)の意味
-
if と配列の組み合わせ
-
ラップ関数とはどんなものですか?
-
卒業研究でよく分からないとこ...
-
【C++】関数ポインタの使い方
-
c言語
-
足して100になるような乱数のア...
-
C言語初心者です、、、お助けく...
-
数字列を3桁ごとにカンマで区切...
-
C言語 エラーの原因がわからな...
-
実数の整数部,小数部の取得
-
課題でつまってます・・・
-
商と剰余を同時に求める(C言語)
-
C言語の配列をC++のvectorに高...
-
std::set<int> で、ある値が何...
おすすめ情報