
No.2ベストアンサー
- 回答日時:
No1 hpsk さんの回答されている通りですが、名前を見てみればイメージしやすいのではないでしょうか。
メモリコンパクション:記憶領域の圧縮
ガーベジコレクション:ゴミ収集
使わなくなった領域 (=ゴミ) を解放する (=収集する) のがガーベジコレクションです。
ちなみに、プログラミング言語の機能としてガーベジコレクション (GC と略すことが多いです) と言った場合、使用しない領域をプログラマが意識することなく、自動で解放してくれる機能を指します。
たとえば、Java には GC があるとか、C/C++ には GC がないとか…。
ただし、ゴミを収集しただけでは、使用可能な領域が断片化してしまうことがあります。
この断片化のことをフラグメンテーションと呼びます。
連続した大きな領域が必要になったときに、フラグメンテーションが多数発生していると、必要な領域が確保できないことがあります。
これを解消するのが、メモリコンパクションです。
# MS-Windows 系 OS で、デフラグという機能があると思いますが、
# これはハードディスクのコンパクション (=フラグメンテーションの
# 解消、デフラグメンテーション) を行っているわけです。
本来の意味としては、メモリコンパクションにガーベジコレクションの意味は含まれないと思うのですが、どうなのでしょうか?>詳しい方、フォローあればお願いします!
確かに、情報処理試験の参考書の中には、両者を同じ意味としているものもあったように思います。
しかし、実使用上は上記のような差異があることを覚えておくと良いと思います。
No.3
- 回答日時:
#1です。
> メモリコンパクションにガーベジコレクションの意味は含まれないと思うのですが
含まれないです。全く別物です。
ただ、メモリの整頓という点では共通しているので、情報処理試験レベルでは同一に扱っているのかもしれません。(私は情報処理試験については詳しく知らないのですが。。。)
大雑把な言い方をすれば、散らかった部屋を整頓するときに、
物を部屋の隅に寄せておくのがコンパクション
いらなくなった物を捨てるのがガーベージコレクション
という感じです。
GCだけやっちゃうと、確かに部屋の空間は増えたけど物はあっちこっちに散乱したまま、という状態になりますね。
No.1
- 回答日時:
コンパクションは、burbeさんの仰るとおり、
「メモリ領域の隙間を集めて、連続した利用可能なメモリ領域を増やす」
ことですが、
ガーベジコレクションは、
「二度と使われないことがわかっているメモリ領域を解放して、再利用できるようにすること」
です。メモリの隙間を集めるという作業は含みません。
C言語のmallocはご存知ですか?
mallocした領域が必要なくなったら、freeをしなければいけませんが、それを自動的にやってくれるものだと思えばいいです。
ただし、ガーベジコレクションのアルゴリズムの中には、ついでにコンパクションもやってしまうものもあります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
医師・看護師・助産師
薬剤師・登録販売者・MR
医療事務・調剤薬局事務
歯科衛生士・歯科助手
臨床検査技師・臨床工学技士
理学療法士・作業療法士・言語聴覚士
臨床心理士・心理カウンセラー・ソーシャルワーカー
介護福祉士・ケアマネージャー・社会福祉士
弁護士・行政書士・司法書士・社会保険労務士
フィナンシャルプランナー(FP)
中小企業診断士
公認会計士・税理士
簿記検定・漢字検定・秘書検定
情報処理技術者・Microsoft認定資格
TOEFL・TOEIC・英語検定
建築士
インテリアコーディネーター
宅地建物取引主任者(宅建)
不動産鑑定士・土地家屋調査士
マンション管理士
電気工事士
美容師・理容師
調理師・管理栄養士・パティシエ
シェフ
保育士・幼稚園教諭
教師・教員
国家公務員・地方公務員
警察官・消防士
その他(職業・資格)
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ページ置き換え LRU方式
-
ドライブ段の意味(回路用語)
-
ステップ数について
-
プログラムの規模を表す単位「k...
-
ubuntuで デイスク/deb/loopと...
-
「下士官に告ぐ」って公の発表...
-
パソコンでインターネット接続...
-
ステップ数??
-
個人が特定の人に対して自分の...
-
ブロック長について
-
hdmiはパラレル?シリアル?
-
リフレッシュ処理の意味を教え...
-
VB.netでDLLを読み込んで実行す...
-
関数呼び出しでのスタック消費量
-
ライン数とステップ数の違いに...
-
CASLとCASL2の違いについて
-
prologでNの階乗の逆関数を考...
-
AUTO-MDIX機能の無効化
-
OSXでHyperCardスタックを使いたい
-
Ethernetヘッダの取得 NDIS
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コンパクションとガーベジコレ...
-
ソフトウェア開発技術者~タス...
-
【電気】フリッカー回路ってな...
-
ミキサの原理
-
SP領域とはなんですか?
-
Ic-PcAn はどこのこと?
-
プルアップ回路とは
-
ソフトウェア開発過去問で理解...
-
ドライブ段の意味(回路用語)
-
電子回路と電気回路の違いを教...
-
リユーザブル,リエントラント...
-
システム企画について
-
CPUの利用効率に関する質問です。
-
DMAチャネルの劣る点とは?
-
[病院関係者の方] 人工呼吸器回...
-
プログラムの規模を表す単位「k...
-
パソコンでインターネット接続...
-
「下士官に告ぐ」って公の発表...
-
個人が特定の人に対して自分の...
-
ubuntuで デイスク/deb/loopと...
おすすめ情報