趣味でプログラミングの勉強をしています。
C言語で、ふと疑問に思いましたので質問させていただきます。
動的に領域を確保するときにはmalloc()にサイズを与えて、その領域のアドレスを取得します。
で、解放するときにはfree()に領域のアドレスを与えます。
ここで疑問に思ったのですが、領域を開放する場合にはその領域のアドレスとサイズが必要ではないかと思うのですが、free()ではアドレスしか与えませんよね?
誰かがアドレスとサイズが対になった情報を管理する必要があると思うのですが、誰が管理しているのでしょうか?
単純に考えてコンパイルしてできた実行形式のファイル中(あるいは呼ばれる外部ライブラリ?)にその機能があると思うのですが、それで合っていますか?
よろしくお願いします。
No.3ベストアンサー
- 回答日時:
ランタイムライブラリ次第。
ってところもありますけどねぇ……。現在の一般的なOSならメモリ割り当てなんかはOSが管理しています。
ソレをC言語のランタイムライブラリで覆い隠している場合もあるでしょう。
その際にサイズなどをどう管理するかはランタイムライブラリ側の問題になります。
# まぁ、そう考えればOS側でもサイズなどの情報を持っていることになりますが…。
アプリケーション起動時にそこそこのサイズでOSからメモリを取得、malloc()などがアプリから呼ばれた時にそこから切り取って使う。という方法をとってもいいワケです。
VisualStudioの製品版ならランタイムライブラリのソースコードも入手可能ですし、GNU Cライブラリならそちらもソースコード一式取得可能でしょう。
X68kのOSではリンクリスト構造で管理してましたねぇ。
# 参考にしたMS-DOSでもたぶん同様…でしょう。
strcut {
前のメモリ管理ブロックへのポインタ
サイズ
次のメモリ管理ブロックへのポインタ
}
みたいな構造体をmalloc()で確保した領域の先頭に置いて、
malloc()の戻り値として返却するときに管理用のメモリブロックの直後のアドレスを返す。
とか……。
で、バッファオーバーランやバッファアンダーランするとこの管理ブロックを破壊するのでfree()や次のmalloc()を実行した際に管理ブロックのリスト構造が壊れてて吹っ飛ぶ…とかね。
# Windowsなら一般保護違反とかですね。X68000ではバスエラーだったかなぁ…。
malloc()で返されたアドレスを保持していない(ポインタ操作で進めたとか)の場合も、free()で渡されたアドレスから管理ブロック探そうとしても変なアドレス指しているので…と。
てきと~に見つけた例。
http://www.valinux.co.jp/technologylibrary/docum …
ご回答ありがとうございました。
答えとしては、アプリケーションからみるとランタイムライブラリが行う。
ただし管理のやりかたは色々あるよ、ということですね。
ご提示いただきましたリンク先の資料は参考になりました。
No.4
- 回答日時:
>「管理する側」とは具体的に何を指すのでしょうか?
Cのランタイムライブラリです。
linuxなどでは、Cのランタイムライブラリはソースが公開されていたりしますので読んでみるといいです。
https://www.gnu.org/software/libc/
http://www.uclibc.org/
http://dmalloc.com/
また管理方法にもいろいろあります。
http://ja.wikipedia.org/wiki/Malloc
ご回答ありがとうございました。
ソースを直接読むのは、今の私にはちょっとキツいですw
管理方法はいろいろな方式があるのですね、勉強になりました。
No.1
- 回答日時:
コンピュータに搭載されているメモリーは全てOSが管理しています。
malloc()でOSに使用したいサイズを申請します、するとこのアドレスを使いなさいと許可が下ります、解放はfree()でOSにこのアドレスで許可された領域はもういらないよと申請します。
ご回答ありがとうございました。
以前、何かで読んだのですがOSからはある程度まとまった量の領域を一度に確保して、mallocはその領域から切り売りしていると書いてありました。
とすると、mallocから与えられる領域の管理はOSではないのかと思い質問させていただきました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
malloc呼び出し時のセグメンテ...
-
C++のnewで確保したメモリーの...
-
LoadLibraryでAccess Violation...
-
画像を読み込む配列の確保。
-
c言語のポインタへの文字列入力...
-
メモリ開放の質問ですが
-
配列の添え字の最大数とは?
-
MFCのCStringについて
-
仮想領域にウインドウを描画
-
newしないオブジェクトについて
-
構造体でchar name[]と*nameの...
-
レジストリ値の取得
-
C++ 構造体のnew
-
c言語のメモリリークについての...
-
JVMヒープサイズ設定について
-
stringの最大サイズ
-
C言語 配列の長さの上限
-
関数から配列を返すには?
-
char型にint型の数値を代入する。
-
Run-Time Check Failure #3とい...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
allocってなんですか?
-
newしないオブジェクトについて
-
c言語のポインタへの文字列入力...
-
ヒープメモリの解放について
-
配列の添え字の最大数とは?
-
stringの最大サイズ
-
C++で、メンバもヒープに確保さ...
-
プログラムが途中で強制終了し...
-
void*型のデータサイズ
-
malloc呼び出し時のセグメンテ...
-
スタック破壊の上手な見つけ方...
-
ビットをローテートするプログ...
-
構造体でchar name[]と*nameの...
-
mallocについて
-
GDI+におけるメモリの開放について
-
ポインタのポインタの初期化法
-
構造体を使ったファイルの読み込み
-
C言語 mallocとfreeについて
-
HEAP に関すること
-
VBからMFC-DLL呼び出し
おすすめ情報