
No.9ベストアンサー
- 回答日時:
>例えばの場合のと申しますか、
>参考のソースを少し教えていただけませんか?
プログラム実行時に初めて処理人数(ninzu)が判明するシステムで、データを読み込んで処理する関数 func() を考えてみます。便宜上データの型は int で言語はCとします。本当はエラー処理(メモリが足らない場合などの)が必要ですが省略します。
void func(int ninzu)
{
int* pData;
intloop;
/* 人数分の int エリアを確保 */
pData = malloc(ninzu * sizeof(int));
/* 人数分の int データを読み込み */
for(loop = 0; loop < ninzu; loop ++)
{
*(pData + loop) = ReadData();
}
/*** 読みこんだデータを使って ***/
/*** なんらかの処理&出力 ***/
/* いらなくなったエリアを開放 */
free(pData);
}
単純化して書くとこんな感じになります。実際にはポインタ pData は単純な int へのポインタではなく構造体へのポインタだったりすることになるでしょう。これだと本当に必要なメモリだけを使うことになり、しかも人数の変動にも対応できることになります。
>こいつは"出来るな"って思われるようになるわけですね。
>他のアプリのことも考えてのプログラムって事ですね。
そうなんですが、人間がコーディングしているのでCやC++で書かれた市販されているアプリケーションでもエリア解放を忘れてしまっているプログラムがよくあります。だから同じアプリを何度も起動、終了を繰り返すと解放されないメモリが蓄積されリソース不足になってしまうやつはそういったバグを持っているということがわかります。
ありがとうございました。
大変分かりやすかったです。
解放忘れたりしているのが、リソース不足の原因にもなっているのですね。
気をつけなければ。
本当にありがとうございました。
No.8
- 回答日時:
> よく変数の寿命とか分からないので、
> みんなグローバルにしていたら、COBOLかよと
> よく言われている私には苦手なトコです。
そんな、難しくないですよ。
自動変数の寿命は、変数を宣言しているところを直前で括っている中括弧の中に
いる間、が、その変数の寿命です。
int xxx()
{
int i;
for (i = 0 ; i < 10 ; ++i) {
int j;
...
{
int k;
...
} … kは、ここまで
} … jは、ここまで
return 0;
} … iは、ここまで
> みんなグローバルにしていたら、COBOLかよと
「って、COBOL やったことあるのかよ」と突っ込みを入れたくなりますよね。
今時は、COBOL を経験すること自体「まれ」ですもんね。
# といいつつも、COBOL のソースを読むはめになりそうなんですが (^^;
COBOLは二種情報処理技術者試験のときに
簡単だからと言う理由で
やらされました。
wark area、変数などを前もって定義しておくので
Cで言うとグローバルの考えしか出来ていないってことです。
だから、いっつもグローバルで定義しちゃうので、
スコープなんて・・・です。
でも、分かりやすかったです。
ありがとうございました。
No.7
- 回答日時:
大きさについては既に出ている通りですが、
他に寿命(?)も違います。
グローバル変数やスタティック変数の場合は、プログラムが実行開始されてから終わるまで,
オート変数の場合,関数の処理が始まってから終わるまでが寿命となりますが、
malloc,calloc等のでとられるメモリは、プログラマが寿命を決めます。
mallocを呼んだ時に生まれ,freeを呼ばれた時に消えます。
(freeされなければ、プログラムが終わるまで)
ところで、unixの共有メモリの話がでてましたけど、
通常はsystem V系のshmget,shmatがシステムコールとして組み込まれていてそれを使いますし、
malloc系の関数はプロセス内部のメモリしか扱わないので,共有メモリの操作には使われないと思いますが。
この回答への補足
変数の寿命を考えることが出来るのですね。
ということは普通にintなどと定義したときよりは
資源が有効に使えるんですね。
よく変数の寿命とか分からないので、
みんなグローバルにしていたら、COBOLかよと
よく言われている私には苦手なトコです。
No.5
- 回答日時:
allocとは要素の数が決まってない場合に使うものです。
たとえば
1)個数が全く予測の出来ない場合
2)通常は10個分ぐらいあればいいけど、ある条件の時には100万個必要になる。
1)の場合は
int nantoka[100]; ってやったんじゃまずいのは分かりますよね? 1000 だって 10000 だってまずいですよ。
2)の場合
常に100万個分のエリアを確保するとものすごく無駄ですよね。
int nantoka[1000000];
allocを使用すればその都度必要な分だけを確保することができて、いらなくなったら削除できるので無駄がなくなるわけです。十分に大きいエリアを最初から取っとけばいいじゃんというコーディングをみんながしたら Windows のメモリは使われてないとこだらけになってすぐにメモリが足りなくなりますよ。(^^;
この回答への補足
回答ありがとうございます。
無駄が無くなる。
こいつは"出来るな"って思われるようになるわけですね。
他のアプリのことも考えてのプログラムって事ですね。
例えばの場合のと申しますか、
参考のソースを少し教えていただけませんか?
どのように定義するのだとかということなども。
お願い致します。
No.4
- 回答日時:
> allocとか使わなくても
> 最初から大きいサイズを用意しておくということでも良いのですよね。
これは、ある意味正解です。
ただし、その大きいサイズを用意するのが無駄すぎる、とか、実メモリが少ない
環境でもそこそこ動いて欲しい(*)場合なんかには、できないアプローチです
よね。
(*) 一杯メモリが積んであるならば、画像を同時に100枚でも処理できるが、
同時に2枚までの処理で良いから、少ないメモリのマシンでも動いてほしい、とか
> でも、いまいちよく理解できませんでした。
ん~、力不足(私が、ね)。
プログラムの動作時に大きさを変えられるかどうか、って違いがあることはOK
なんですよね。
であれば、今は、その程度の理解でも良いかも。
「スタック」とか「ヒープ」とかっていう言葉に遭遇してから、理解を深めても
十分。
この回答への補足
ありがとうございます。
一歩進みました。
実際にサイズが変化するようなものに
であったことが無かっただけにイメージが湧きませんでした。
プラスして、実装メモリなんてモノも全く気にしていませんでした。
allocとかが使えるようになると、PC資源の
有効利用ができるって言うことですよね。

No.3
- 回答日時:
失礼しました。
APとはアプリケーションの略で使いました。
UNIXでは共有メモリという考えでよく使用されるのですが、
例えばA、Bという二つのアプリケーション(以下AP)があるとします。
Aでメモリ領域を確保しその領域に"あいう"と書き込むとします。
Bでそのメモリ領域を参照し"あいう"を取得する場合には、
メモリ領域の確保にalloc系の関数が使用されます。(malloc、globaalloc等々)
伝わりましたでしょうか…。
No.1
- 回答日時:
> メモリ領域を確保するとかって言うことらしいのですが、
> charとかintとかで定義するのとは違うのですか?
違います。
「欲しいサイズのメモリを使えるようにする」という意味では、ほとんど差が無い
のですが、その用意の仕方が違います。
変数で宣言する場合には、あらかじめソースを書く段階で、型とその大きさ(配列の
個数)が決っていなければなりません。
それだけで、不自由が無ければそれで良いのですが、実際には、プログラムを動かして
いるときに、初めてその大きさが決まり、そのサイズのメモリが欲しい、というときが
あります。
その場合には alloc 系の関数を使うしかないです。
と言いつつも、新しい C の規格(C99)では、alloc 系の関数を使わなくても、大きさを
後から決められる配列が使えたりします。
★こんなソースがかけちゃう!
int size;
scanf("%d", &size);
int data[size]; /* おおっと! */
/* 今までの C では、こう書くしかなかったんです。
int size;
int *data;
scanf("%d", &size);
data = malloc(size * sizeof(int));
*/
後、細かいことを言うと、変数の宣言で用意されるメモリの場所と、alloc 系の関数で
用意される場所が微妙に(それぞれの中でもやり方によって)違います。まあ、この
あたりは、もっと突っ込んだことをやるようになってから覚えてもいいでしょう。
この回答への補足
回答ありがとうございます。
でも、いまいちよく理解できませんでした。
大変申し訳ありませんが、
さらに、詳しく(無理だとは思いますが、)お願いできませんでしょうか?
なんとなくでは、分かってきたんですが
分かった・分からないかと聞かれた場合に分からないとなってしまいますもので。
何処が分からないかと言うと、イメージが湧きにくいというのも
有ると思うのですが、allocとか使わなくても
最初から大きいサイズを用意しておくということでも良いのですよね。
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語の質問です。 以下の命令を実行するプログラムを作りました ①文字列aとbの長さを表示 ②aとb 1 2022/04/29 15:35
- C言語・C++・C# sprintf()の使い方について 1 2022/08/17 16:16
- C言語・C++・C# ポインタの型変換、どうやるんでしたっけ? 2 2022/03/28 11:00
- C言語・C++・C# スタックフレームの消滅 6 2023/05/20 12:33
- CPU・メモリ・マザーボード ストリーミングの一時処理用の領域について 1 2023/04/11 21:55
- C言語・C++・C# 宣言する関数の形が決まっている状態で、 str1とstr2の文字列をこの順に引っ付けてstrに保存し 2 2022/05/30 18:21
- 日本語 「に」について 9 2022/10/25 16:32
- 高校 合成関数の定義域につきまして 1 2022/05/18 17:26
- C言語・C++・C# C言語初心者 構造体 課題について 2 2023/03/10 19:48
- C言語・C++・C# C言語初心者 構造体 課題について 1 2023/03/10 19:30
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ビットをローテートするプログ...
-
プログラムが途中で強制終了し...
-
メモリ解放について
-
dllを使用しVB側に文字列...
-
c言語のポインタへの文字列入力...
-
allocってなんですか?
-
newしないオブジェクトについて
-
C言語 mallocとfreeについて
-
JVMヒープサイズ設定について
-
配列の添え字の最大数とは?
-
GDI+におけるメモリの開放について
-
写真のc言語の問題がa以外わか...
-
CreateFileMapping について
-
C言語 配列の長さの上限
-
関数から配列を返すには?
-
Run-Time Check Failure #3とい...
-
先頭アドレスとは何ですか?
-
C# DataGridView のヘッダーセ...
-
配列の問題
-
System.IO.Directory.GetFiles...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
c言語のポインタへの文字列入力...
-
allocってなんですか?
-
newしないオブジェクトについて
-
malloc呼び出し時のセグメンテ...
-
入れ子になった構造体について
-
ヒープメモリの解放について
-
ビットをローテートするプログ...
-
C++で、メンバもヒープに確保さ...
-
void*型のデータサイズ
-
Win32APIでのメモリ管理について
-
配列の添え字の最大数とは?
-
C++のnewで確保したメモリーの...
-
プログラムが途中で強制終了し...
-
C言語 mallocとfreeについて
-
LoadLibraryでAccess Violation...
-
win32APIのHeapAlloc()の使い方...
-
グローバル変数のサイズ
-
MFCのCStringについて
-
メモリ不足になってしまう。
-
DLLで同じメモリ領域を参照する...
おすすめ情報