学校でファイル読み込みの課題を今しているのですが、ファイルの行数が増えた場合にも対応していて、且つ無駄な領域を使わないようなファイル読み込みをするのに困っています。
流れとしては
csvファイルから内容を読み込む
↓
カンマで分割し、構造体に格納
↓
その格納した構造体を返す
という動きをしたいのですが、構造体をmallocで動的にメモリ確保する時にも、行数の取得が必要になってきて・・・
一度行数を調べてから、処理を行う方法を取るか、他のchar型配列か何かに一度全てを格納して、そのときにカウントした行数を使って構造体のメモリを動的に確保する・・・くらいまでは思いついたのですが、始め全てを格納する時点でもまた動的にメモリを格納する方法が思いつかなくて・・・・
やはりどこかで多めに領域を取り、そこに格納する手を使うしかないのでしょうか?
ご教授お願いします。
No.3ベストアンサー
- 回答日時:
データを格納する構造体とその構造体の配列(ダブルポインタ)を動的に確保していけばいいように思います
初回は
struct tagData** pArStruct = (struct tagData**)malloc(sizeof(struct tagData*) );
struct tagData* pStruct = (struct tagData)malloc( sizeof(struct tagData) );
int nCnt = 0;
pArStruct[nCnt] = pStruct;
と確保します
このpStructにデータを読み込みます
次回からは
nCnt++;
// struct tagStructの配列を拡張
pArStruct = (struct tagStruct**)realloc(pArStruct, sizeof(struct tagStruct*) * ( nCnt + 1 ) );
// 次の行用の構造体を確保
pStruct = (struct tagStruct)malloc( sizeof(struct tagStruct) );
pArStruct[nCnt] = pStruct;
といった具合で拡張していきます
エラーチェックなどは省略していますのでmalloc/reallocなどからの戻り値がNULLでないのかをチェックしましょう
不要になった動的に確保した領域はfreeなどで開放しましょう
for ( int n = 0; n < nCnt; n++ ) {
// pStruct = malloc( sizeof(struct tagData) );で確保した
// 配列の要素を開放
free( pArStruct[n] );
}
// malloc/reallocで確保した pArStruct自体を開放
free( pArStruct );
No.1
- 回答日時:
非常にいい質問ですね。
この問題は、専門家でも、問題となる重要な問題です。
対策案としては、2案が考えられます。
1案:
予め、起動パラメータで、ファイルのサイズの最大行を与えておく。その行数分データを格納できるの領域のみ、mallocし、それを越えた場合は、エラーメッセージをだして、ギブアップする。
(ギブアップした場合は、次に起動パラメータの値を大きくして再度起動すればよい。)
2案:
最初はmallocしません。その代わり、バッファに格納できない場合、バッファをmallocします。その場合、例えば1000行分単位で拡張するとします。
(1)最初はないので、1行読み込んだときに、バッファを1000行分確保する。
(2)1001行を読み込んだとき、今までのバッファサイズ+1000行分のバッファを確保し、そこへ今までのバッファの内容をコピーする。
そして、今までのバッファを解放する。
(3)2002行を読み込んだとき、(2)と同様の処理を行う。
以下同様。もちろん、その都度、mallocの戻り値はチェックして、メモリ確保エラーの場合は、ギブアップします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 2 2023/07/21 10:51
- Excel(エクセル) 【VBA】指定フォルダに格納中のテキストファイルをエクセルで処理し結果のエクセルを新規フォルダに保存 1 2022/03/25 14:19
- Visual Basic(VBA) 顧客ごとに違う点検案内を作成するマクロ 4 2022/09/16 05:34
- その他(社会・学校・職場) 業務内容についてどう思いますか? 私は客先の仕事を下請けとして行うという仕事をしていますが、(客先の 2 2022/05/04 16:17
- その他(社会・学校・職場) 業務内容についてどう思いますか? 私は客先の仕事を下請けとして行うという仕事をしていますが、(客先の 3 2022/05/04 17:55
- C言語・C++・C# このプログラミング誰か教えてくれませんか 3 2022/05/13 17:27
- 労働相談 合意済み仕様の商品納入後における仕様変更要求への対応について 5 2023/04/19 09:41
- C言語・C++・C# このプログラミング誰か教えてくれませんか 2 2022/05/14 09:45
- C言語・C++・C# C言語 2 2022/07/21 00:02
- Excel(エクセル) PowerQueryに詳しい方教えてください(Office365) 1 2022/07/24 21:11
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
c言語のポインタへの文字列入力...
-
大容量の静的な確保の限界値
-
allocってなんですか?
-
malloc呼び出し時のセグメンテ...
-
OpenCV cvLoadImageについて
-
malloc(0)でNULLが返された
-
malloc()関数内でセングメント...
-
new、memset()、エラー
-
構造体でchar name[]と*nameの...
-
LPWSTRのコピー
-
Win32APIでのメモリ管理について
-
スタック破壊の上手な見つけ方...
-
プログラムが途中で強制終了し...
-
C言語 mallocとfreeについて
-
DLLのマルチスレッドの動作につ...
-
GUIアプリケーションで連続領域...
-
デストラクタを呼びたい
-
fread関数および動的なメモリ確...
-
グローバル変数のサイズ
-
void*型のデータサイズ
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
c言語のポインタへの文字列入力...
-
newしないオブジェクトについて
-
allocってなんですか?
-
malloc呼び出し時のセグメンテ...
-
ヒープメモリの解放について
-
配列の添え字の最大数とは?
-
C++で、メンバもヒープに確保さ...
-
ビットをローテートするプログ...
-
プログラムが途中で強制終了し...
-
構造体でchar name[]と*nameの...
-
stringの最大サイズ
-
mallocで確保するメモリの領域...
-
C言語 mallocとfreeについて
-
void*型のデータサイズ
-
大容量の静的な確保の限界値
-
DLLのマルチスレッドの動作につ...
-
スタック破壊の上手な見つけ方...
-
C++のnewで確保したメモリーの...
-
行列内の行の交換,列の交換を...
-
LPTSTR型の変数に文字を格納
おすすめ情報