プログラム言語(全23問中17問目)

プログラムの実行時に利用される記憶領域にスタック領域とヒープ領域がある。それらの領域に関する記述のうち,適切なものはどれか。

出典:平成21年春期 問18

  • サブルーチンからの戻り番地の退避にはスタック領域が,割当てと解放の順序に関連のないデータにはヒープ領域が使用される。
  • スタック領域には未使用領域が存在するが,ヒープ領域には未使用領域は存在しない。
  • ヒープ領域はスタック領域の予備領域であり,スタック領域が一杯になった場合にヒープ領域が動的に使用される。
  • ヒープ領域も構造的にはスタックと同じプッシュポップの操作によって,データの格納と取出しを行う。
正解 問題へ
分野:テクノロジ系
中分類:アルゴリズムとプログラミング
小分類:プログラム言語
解説
スタック領域とヒープ領域の違いについては以下の通りです。
スタック領域
一般にコールスタック・制御スタックと呼ばれている。LIFO方式で構成されプログラムの実行中サブルーチンの情報を記憶しておくメモリ領域。
サブルーチン終了後の戻りアドレスや局所変数などを保持する。
ヒープ領域
多くの場合、2つのラベルを持つ双方向リスト(リンク構造)で構成されプログラム上から動的(任意)に確保できるメモリ領域。
動的にメモリ取得・解放を繰り返すことによりメモリ上にどこからも参照されない領域(ガベージ)が発生する。
したがって正しい説明は「ア」です。
  • 正しい。
  • ヒープの初期状態は「未使用」状態であり、メモリの動的確保によって「使用」領域と「未使用」領域に分かれていきます。
  • ヒープとスタック領域の役割は異なるため、予備領域ではありません。
  • ヒープ領域は、多くの場合、双方向リストによるリンク構造で構成されているので誤りです。

この問題の出題歴


Pagetop