Top

G1CollectedHeap クラス関連のクラス (YoungList, MutatorAllocRegion, G1CollectedHeap, GCLabBitMapClosure, GCLabBitMap, G1ParGCAllocBuffer, G1ParScanThreadState, 及びそれらの補助クラス(RefineCardTableEntryClosure, ClearLoggedCardTableEntryClosure, RedirtyLoggedCardTableEntryClosure, RedirtyLoggedCardTableEntryFastClosure, PostMCRemSetClearClosure, PostMCRemSetInvalidateClosure, RebuildRSOutOfRegionClosure, ParRebuildRSTask, SumUsedClosure, SumUsedRegionsClosure, IterateOopClosureRegionClosure, IterateObjectClosureRegionClosure, SpaceClosureRegionClosure, ResetClaimValuesClosure, CheckClaimValuesClosure, VerifyLivenessOopClosure, VerifyObjsInRegionClosure, PrintObjsInRegionClosure, VerifyRegionClosure, VerifyRootsClosure, G1ParVerifyTask, PrintRegionClosure, VerifyMarkedObjsClosure, FindGCAllocRegion, G1IsAliveClosure, G1KeepAliveClosure, UpdateRSetDeferred, RemoveSelfPointerClosure, G1ParEvacuateFollowersClosure, G1ParTask, SaveMarksClosure, G1ParCleanupCTTask, G1VerifyCardTableCleanup, NoYoungRegionsClosure, RegionResetter, VerifyRegionListsClosure))

これらは, Java ヒープ領域を管理するためのクラス (See: here for details).

Java ヒープ領域を管理するクラスは使用する GC アルゴリズムによって異なるが, これらのクラスは GC アルゴリズムが G1GC の場合に使用される. (See: GenCollectedHeap, ParallelScavengeHeap)

クラス一覧(class list)


G1CollectedHeap

概要(Summary)

Java ヒープ領域の管理を担当するクラス(CollectedHeapクラス)の1つ (See: here for details).

このクラスは, GC アルゴリズムが G1GC の場合用.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    class G1CollectedHeap : public SharedHeap {

内部構造(Internal structure)

定義されているフィールドは以下の通り.

Concurrent Marking を実行中かどうかを示す. 以下のメソッドがアクセサ.

* G1CollectedHeap::set_marking_complete()
* G1CollectedHeap::set_marking_started()
* G1CollectedHeap::mark_in_progress()

Minor GC が失敗した際に true になる (このフィールドが true だと, Minor GC 後に失敗した GC の後始末が行われる (See: here for details)).

Minor GC が失敗した場合の処理で(のみ)使用されるフィールド. G1CollectedHeap::handle_evacuation_failure_common() の呼び出しが再帰にならないようにするためのフラグ (See: here for details).

Minor GC 処理中に使用されるフィールド. Collection Set に含まれた HeapRegion の中で Barrier Set をクリアする必要があるものが格納される (See: G1CollectedHeap::push_dirty_cards_region(), G1CollectedHeap::pop_dirty_cards_region()).

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // Storage for the G1 heap (excludes the permanent generation).
      VirtualSpace _g1_storage;
      MemRegion    _g1_reserved;

      // The part of _g1_storage that is currently committed.
      MemRegion _g1_committed;

      // The maximum part of _g1_storage that has ever been committed.
      MemRegion _g1_max_committed;

      // The master free list. It will satisfy all new region allocations.
      MasterFreeRegionList      _free_list;

      // The secondary free list which contains regions that have been
      // freed up during the cleanup process. This will be appended to the
      // master free list when appropriate.
      SecondaryFreeRegionList   _secondary_free_list;

      // It keeps track of the humongous regions.
      MasterHumongousRegionSet  _humongous_set;

      // The number of regions we could create by expansion.
      size_t _expansion_regions;

      // The block offset table for the G1 heap.
      G1BlockOffsetSharedArray* _bot_shared;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The sequence of all heap regions in the heap.
      HeapRegionSeq* _hrs;

      // Alloc region used to satisfy mutator allocation requests.
      MutatorAllocRegion _mutator_alloc_region;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The to-space memory regions into which objects are being copied during
      // a GC.
      HeapRegion* _gc_alloc_regions[GCAllocPurposeCount];
      size_t _gc_alloc_region_counts[GCAllocPurposeCount];
      // These are the regions, one per GCAllocPurpose, that are half-full
      // at the end of a collection and that we want to reuse during the
      // next collection.
      HeapRegion* _retained_gc_alloc_regions[GCAllocPurposeCount];
      // This specifies whether we will keep the last half-full region at
      // the end of a collection so that it can be reused during the next
      // collection (this is specified per GCAllocPurpose)
      bool _retain_gc_alloc_region[GCAllocPurposeCount];

      // A list of the regions that have been set to be alloc regions in the
      // current collection.
      HeapRegion* _gc_alloc_region_list;

      // Helper for monitoring and management support.
      G1MonitoringSupport* _g1mm;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // Outside of GC pauses, the number of bytes used in all regions other
      // than the current allocation region.
      size_t _summary_bytes_used;

      // This is used for a quick test on whether a reference points into
      // the collection set or not. Basically, we have an array, with one
      // byte per region, and that byte denotes whether the corresponding
      // region is in the collection set or not. The entry corresponding
      // the bottom of the heap, i.e., region 0, is pointed to by
      // _in_cset_fast_test_base.  The _in_cset_fast_test field has been
      // biased so that it actually points to address 0 of the address
      // space, to make the test as fast as possible (we can simply shift
      // the address to address into it, instead of having to subtract the
      // bottom of the heap from the address before shifting it; basically
      // it works in the same way the card table works).
      bool* _in_cset_fast_test;

      // The allocated array used for the fast test on whether a reference
      // points into the collection set or not. This field is also used to
      // free the array.
      bool* _in_cset_fast_test_base;

      // The length of the _in_cset_fast_test_base array.
      size_t _in_cset_fast_test_length;

      volatile unsigned _gc_time_stamp;

      size_t* _surviving_young_words;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // Keeps track of how many "full collections" (i.e., Full GCs or
      // concurrent cycles) we have completed. The number of them we have
      // started is maintained in _total_full_collections in CollectedHeap.
      volatile unsigned int _full_collections_completed;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The number of regions allocated to hold humongous objects.
      int         _num_humongous_regions;
      YoungList*  _young_list;

      // The current policy object for the collector.
      G1CollectorPolicy* _g1_policy;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The g1 remembered set of the heap.
      G1RemSet* _g1_rem_set;
      // And it's mod ref barrier set, used to track updates for the above.
      ModRefBarrierSet* _mr_bs;

      // A set of cards that cover the objects for which the Rsets should be updated
      // concurrently after the collection.
      DirtyCardQueueSet _dirty_card_queue_set;

      // The Heap Region Rem Set Iterator.
      HeapRegionRemSetIterator** _rem_set_iterator;

      // The closure used to refine a single card.
      RefineCardTableEntryClosure* _refine_cte_cl;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // A DirtyCardQueueSet that is used to hold cards that contain
      // references into the current collection set. This is used to
      // update the remembered sets of the regions in the collection
      // set in the event of an evacuation failure.
      DirtyCardQueueSet _into_cset_dirty_card_queue_set;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The concurrent marker (and the thread it runs in.)
      ConcurrentMark* _cm;
      ConcurrentMarkThread* _cmThread;
      bool _mark_in_progress;

      // The concurrent refiner.
      ConcurrentG1Refine* _cg1r;

      // The parallel task queues
      RefToScanQueueSet *_task_queues;

      // True iff a evacuation has failed in the current collection.
      bool _evacuation_failed;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // When one is non-null, so is the other.  Together, they each pair is
      // an object with a preserved mark, and its mark value.
      GrowableArray<oop>*     _objs_with_preserved_marks;
      GrowableArray<markOop>* _preserved_marks_of_objs;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The stack of evac-failure objects left to be scanned.
      GrowableArray<oop>*    _evac_failure_scan_stack;
      // The closure to apply to evac-failure objects.

      OopsInHeapRegionClosure* _evac_failure_closure;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // True iff an invocation of "drain_scan_stack" is in progress; to
      // prevent unnecessary recursion.
      bool _drain_in_progress;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // Instance of the concurrent mark is_alive closure for embedding
      // into the reference processor as the is_alive_non_header. This
      // prevents unnecessary additions to the discovered lists during
      // concurrent discovery.
      G1CMIsAliveClosure _is_alive_closure;

      // ("Weak") Reference processing support
      ReferenceProcessor* _ref_processor;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      SubTasksDone* _process_strong_tasks;

      volatile bool _free_regions_coming;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The following is just to alert the verification code
      // that a full collection has occurred and that the
      // remembered sets are no longer up to date.
      bool _full_collection;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      // The dirty cards region list is used to record a subset of regions
      // whose cards need clearing. The list if populated during the
      // remembered set scanning and drained during the card table
      // cleanup. Although the methods are reentrant, population/draining
      // phases must not overlap. For synchronization purposes the last
      // element on the list points to itself.
      HeapRegion* _dirty_cards_region_list;
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
      size_t _max_heap_capacity;

詳細(Details)

See: here for details


YoungList

概要(Summary)

G1CollectedHeap クラス用の補助クラス.

オブジェクトの確保用に最近使用された HeapRegion を記録しておくためのコンテナクラス(線形リスト). この中に格納されている HeapRegion が世代別 GC の New 領域 (Eden および Survivor 領域) に相当する . このリストがある程度長くなると Minor GC 処理が開始される.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    class YoungList : public CHeapObj {

使われ方(Usage)

インスタンスの格納場所(where its instances are stored)

各 G1CollectedHeap オブジェクトの _young_list フィールドに(のみ)格納されている.

生成箇所(where its instances are created)

G1CollectedHeap::G1CollectedHeap() 内で(のみ)生成されている.

使用箇所(where its instances are used)

以下のパスで(のみ) HeapRegion が追加されている.

G1CollectedHeap::attempt_allocation()
-> G1CollectedHeap::attempt_allocation_slow()
   -> G1AllocRegion::attempt_allocation_locked()
      -> G1AllocRegion::new_alloc_region_and_allocate()
         -> MutatorAllocRegion::allocate_new_region()
            -> G1CollectedHeap::new_mutator_alloc_region()
               -> G1CollectedHeap::set_region_short_lived_locked()
                  -> YoungList::push_region()
   -> G1AllocRegion::attempt_allocation_force()
      -> G1AllocRegion::new_alloc_region_and_allocate()
         -> (同上)

...
-> G1CollectedHeap::attempt_allocation_at_safepoint()
   -> G1AllocRegion::attempt_allocation_locked()
      -> (同上)

詳細(Details)

See: here for details


MutatorAllocRegion

概要(Summary)

G1AllocRegion クラスの具象サブクラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    class MutatorAllocRegion : public G1AllocRegion {

使われ方(Usage)

インスタンスの格納場所(where its instances are stored)

各 G1CollectedHeap オブジェクトの _mutator_alloc_region フィールドに(のみ)格納されている.

生成箇所(where its instances are created)

(G1CollectedHeap クラスの _mutator_alloc_region フィールドは, ポインタ型ではなく実体なので, G1CollectedHeap オブジェクトの生成時に一緒に生成される)

詳細(Details)

See: here for details


G1ParGCAllocBuffer

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される補助クラス (See: here for details).

Minor GC 中に各 GC Thread (GangWorker) がコピー先として使用する To 領域や Old 領域を管理するクラス (論文中では "GCLABs(GC thread local allocation buffers)").

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    class G1ParGCAllocBuffer: public ParGCAllocBuffer {

使われ方(Usage)

インスタンスの格納場所(where its instances are stored)

以下の箇所に(のみ)格納されている

To 領域用の HeapRegin を管理する

Old 領域用の HeapRegin を管理する

生成箇所(where its instances are created)

(なお, このクラスは CHeapObj クラスだが, G1ParScanThreadState クラス(StackObjクラス)のフィールドとしてのみ生成されている)

備考(Notes)

なお, スーパークラスの ParGCAllocBuffer は parNew/ 以下で定義されている模様 (何か妙な気もするが, 必要ないのにわざわざ新しいクラスを定義するのも無駄がある?? #TODO).

詳細(Details)

See: here for details


GCLabBitMap

概要(Summary)

G1ParGCAllocBuffer クラス内で使用される補助クラス (つまり, G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される補助クラス (See: here for details)).

G1ParGCAllocBuffer がコピー先として使用している HeapRegion 内のオブジェクトについて, どのオブジェクトが生きているかという情報を記録していくためのビットマップ. 作業中に一時的に情報がここに蓄えられ, 適当な契機で ConcurrentMark 内にある mark bitmap (CMBitMap) に反映される.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    class GCLabBitMap: public BitMap {

使われ方(Usage)

使用方法の概要(how to use)

  1. GCLabBitMap::GCLabBitMap() 又は GCLabBitMap::set_buffer() で, ターゲットとなる HeapRegion を設定する.
  2. GCLabBitMap::mark() で, 指定箇所のオブジェクトが live だと記録する (= ビットを立てる).
  3. GCLabBitMap::retire() で, 記録結果を ConcurrentMark 内の mark bitmap (CMBitMap) に反映する.

インスタンスの格納場所(where its instances are stored)

各 G1ParGCAllocBuffer オブジェクトの _bitmap フィールドに(のみ)格納されている.

生成箇所(where its instances are created)

(G1ParGCAllocBuffer クラスの _bitmap フィールドは, ポインタ型ではなく実体なので, G1ParGCAllocBuffer オブジェクトの生成時に一緒に生成される)

詳細(Details)

See: here for details


GCLabBitMapClosure

概要(Summary)

デバッグ用(開発時用)のクラス (#ifndef PRODUCT 時にしか定義されない).

ConcurrentMark オブジェクト内の mark bitmap が正しいかどうかのチェックを行う.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    #ifndef PRODUCT
    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    class GCLabBitMapClosure: public BitMapClosure {

使われ方(Usage)

GCLabBitMap::verify() 内で(のみ)使用されている.

内部構造(Internal structure)

GCLabBitMapClosure::do_bit() の内部は, 単に guarantee() によるチェックを行うだけ.

詳細(Details)

See: here for details


G1ParScanThreadState

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される補助クラス(StackObjクラス) (See: here for details).

処理を行う GC Thread (WorkGang) の状態を管理するためのクラス. 以下のような情報を格納している.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp))
    class G1ParScanThreadState : public StackObj {

使われ方(Usage)

G1ParTask::work() 内で(のみ)使用されている.

詳細(Details)

See: here for details


RefineCardTableEntryClosure

概要(Summary)

G1CollectedHeap の Remembered Set の修正処理(= ConcurrentG1RefineThread の処理)で使用される補助クラス (See: here for details).

DirtyCardQueue 内の各 card に対して, 実際に Remembered Set の修正処理を行う Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class RefineCardTableEntryClosure: public CardTableEntryClosure {

使われ方(Usage)

インスタンスの格納場所(where its instances are stored)

各 G1CollectedHeap オブジェクトの _refine_cte_cl フィールドに(のみ)格納されている.

生成箇所(where its instances are created)

G1CollectedHeap::initialize() 内で(のみ)生成されている.

使用箇所(where its instances are used)

JavaThread::dirty_card_queue_set() に格納されている DirtyCardQueueSet オブジェクトの中で(のみ)使用されている (より正確に言うと, G1CollectedHeap::refine_cte_cl フィールドは, この DirtyCardQueueSet オブジェクトを対象とした DirtyCardQueueSet::setclosure() の引数としてのみ参照される).

詳細(Details)

See: here for details


ClearLoggedCardTableEntryClosure

概要(Summary)

?? (このクラスは使用箇所が見当たらない...)

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class ClearLoggedCardTableEntryClosure: public CardTableEntryClosure {

使われ方(Usage)

G1CollectedHeap::check_ct_logs_at_safepoint() 内で(のみ)使用されている (が, この関数自体が使われていないような...?? #TODO)

詳細(Details)

See: here for details


RedirtyLoggedCardTableEntryClosure

概要(Summary)

?? (このクラスは使用箇所が見当たらない...)

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class RedirtyLoggedCardTableEntryClosure: public CardTableEntryClosure {

使われ方(Usage)

G1CollectedHeap::check_ct_logs_at_safepoint() 内で(のみ)使用されている (が, この関数自体が使われていないような...?? #TODO)

詳細(Details)

See: here for details


RedirtyLoggedCardTableEntryFastClosure

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される Closure クラス (See: here for details).

G1CollectedHeap::dirty_card_queue_set() 内の各 card について (= 処理が遅延されていた各 card について), card の dirty 化を行う.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class RedirtyLoggedCardTableEntryFastClosure : public CardTableEntryClosure {

使われ方(Usage)

G1CollectedHeap::evacuate_collection_set() 内で(のみ)使用されている

備考(Notes)

develop オプションである G1DeferredRSUpdate を false に変更した場合, このクラスは使用されなくなる.

詳細(Details)

See: here for details


PostMCRemSetClearClosure

概要(Summary)

G1CollectedHeap の Major GC 処理で使用される Closure クラス (See: here for details).

(Major GC の処理後に) 全ての HeapRegion の Remembered Set 情報をリセットするための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class PostMCRemSetClearClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::do_collection() 内で(のみ)使用されている

詳細(Details)

See: here for details


PostMCRemSetInvalidateClosure

概要(Summary)

?? (このクラスは使用箇所が見当たらない...)

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class PostMCRemSetInvalidateClosure: public HeapRegionClosure {

詳細(Details)

See: here for details


RebuildRSOutOfRegionClosure

概要(Summary)

G1CollectedHeap の Major GC 処理で使用される補助クラス (See: here for details).

(Major GC の処理後に) 全ての HeapRegion の Remembered Set 情報を作成し直すための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class RebuildRSOutOfRegionClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::do_collection() 内で(のみ)使用されている (より正確には, G1CollectedHeap::do_collection() 内と, そこから呼び出される ParRebuildRSTask::work() 内で使用される補助クラス).

内部構造(Internal structure)

実際の処理のほとんどは UpdateRSOopClosure に丸投げしている (より正確に言うと, RebuildRSOutOfRegionClosure が各 HeapRegion に対して呼び出され, その中で HeapRegion 内の各 oop に対して UpdateRSOopClosure が呼び出される).

詳細(Details)

See: here for details


ParRebuildRSTask

概要(Summary)

G1CollectedHeap の Major GC 処理で使用される補助クラス (See: here for details).

(Major GC の処理後に) 全ての HeapRegion の Remembered Set 情報を作成し直すための AbstractGangTask クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class ParRebuildRSTask: public AbstractGangTask {

使われ方(Usage)

G1CollectedHeap::do_collection() 内で(のみ)使用されている

内部構造(Internal structure)

実際の処理は RebuildRSOutOfRegionClosure に丸投げしている.

詳細(Details)

See: here for details


SumUsedClosure

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)および Major GC 処理で使用される補助クラス (See: here and here for details).

ヒープ中の生きているオブジェクトの合計量 (byte 数) を計算する.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class SumUsedClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::recalculate_used() 内で(のみ)使用されている

詳細(Details)

See: here for details


SumUsedRegionsClosure

概要(Summary)

デバッグ用(開発時用)のクラス (#ifndef PRODUCT 時にしか定義されない).

生きているオブジェクトが存在する HeapRegion の個数を調べる.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    #ifndef PRODUCT
    class SumUsedRegionsClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::recalculate_used_regions() 内で(のみ)使用されている (なお, この関数自体も #ifndef PRODUCT 時にしか定義されない).

詳細(Details)

See: here for details


IterateOopClosureRegionClosure

概要(Summary)

G1CollectedHeap の処理で使用される補助クラス.

他の OopClosure と組み合わせて使用される Closure クラス. 指定された OopClosure をある HeapRegion 内の全てのポインタフィールドに対して適用する.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    // Iterates an OopClosure over all ref-containing fields of objects
    // within a HeapRegion.

    class IterateOopClosureRegionClosure: public HeapRegionClosure {

使用箇所(where its instances are used)

以下の箇所で(のみ)使用されている.

詳細(Details)

See: here for details


IterateObjectClosureRegionClosure

概要(Summary)

G1CollectedHeap の処理で使用される補助クラス.

他の ObjectClosure と組み合わせて使用される Closure クラス. 指定された ObjectClosure をある HeapRegion 内の全てのオブジェクトに対して適用する.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    // Iterates an ObjectClosure over all objects within a HeapRegion.

    class IterateObjectClosureRegionClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::object_iterate() 内で(のみ)使用されている

詳細(Details)

See: here for details


SpaceClosureRegionClosure

概要(Summary)

G1CollectedHeap の処理で使用される補助クラス.

他の SpaceClosure と組み合わせて使用される Closure クラス. 指定された SpaceClosure をある HeapRegion に対して適用する.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    // Calls a SpaceClosure on a HeapRegion.

    class SpaceClosureRegionClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::space_iterate() 内で(のみ)使用されている

詳細(Details)

See: here for details


ResetClaimValuesClosure

概要(Summary)

G1CollectedHeap の Major GC 処理で使用される補助クラス (See: here for details).

(Major GC の処理後に) 全ての HeapRegion の region claim values 情報 (HeapRegion::_claimed フィールド) をリセットするための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class ResetClaimValuesClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::reset_heap_region_claim_values() 内で(のみ)使用されている

詳細(Details)

See: here for details


CheckClaimValuesClosure

概要(Summary)

デバッグ用(開発時用)のクラス (#ifdef ASSERT 時にしか定義されない).

全ての HeapRegion の region claim values 情報 (HeapRegion::_claimed フィールド), 及び Humongous 情報が正しいかどうかのチェックを行う.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    #ifdef ASSERT
    // This checks whether all regions in the heap have the correct claim
    // value. I also piggy-backed on this a check to ensure that the
    // humongous_start_region() information on "continues humongous"
    // regions is correct.

    class CheckClaimValuesClosure : public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::check_heap_region_claim_values() 内で(のみ)使用されている

詳細(Details)

See: here for details


VerifyLivenessOopClosure

概要(Summary)

デバッグ用(開発時用)のクラス.

VerifyObjsInRegionClosure クラス内で使用される補助クラス(Closureクラス). 処理対象のオブジェクトが生きていることをチェックする.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class VerifyLivenessOopClosure: public OopClosure {

使われ方(Usage)

VerifyObjsInRegionClosure::do_object() 内で(のみ)使用されている

詳細(Details)

See: here for details


VerifyObjsInRegionClosure

概要(Summary)

デバッグ用(開発時用)のクラス.

VerifyRegionClosure クラス内で使用される補助クラス(Closureクラス). 「処理対象のオブジェクトが生きていれば, その中のポインタフィールドが指す先も全て生きている」ことをチェックする. また, Concurrent Mark 開始時以前に確保されたオブジェクトの中で現在も生きているものの量(byte 数)も計算している.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class VerifyObjsInRegionClosure: public ObjectClosure {

使われ方(Usage)

VerifyRegionClosure::doHeapRegion() 内で(のみ)使用されている

詳細(Details)

See: here for details


PrintObjsInRegionClosure

概要(Summary)

?? (このクラスは使用箇所が見当たらない...)

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class PrintObjsInRegionClosure : public ObjectClosure {

詳細(Details)

See: here for details


VerifyRegionClosure

概要(Summary)

デバッグ用(開発時用)のクラス.

HeapRegion が正しい状態になっていることをチェックするための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class VerifyRegionClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::verify() 内で(のみ)使用されている (より正確には, G1CollectedHeap::verify() 内と, そこから呼び出される G1ParVerifyTask::work() 内で使用される補助クラス).

詳細(Details)

See: here for details


VerifyRootsClosure

概要(Summary)

デバッグ用(開発時用)のクラス.

root から指されている先が生きていることをチェックするための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class VerifyRootsClosure: public OopsInGenClosure {

使われ方(Usage)

G1CollectedHeap::verify() 内で(のみ)使用されている.

詳細(Details)

See: here for details


G1ParVerifyTask

概要(Summary)

デバッグ用(開発時用)のクラス.

HeapRegion が正しい状態になっていることをチェックするための AbstractGangTask クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    // This is the task used for parallel heap verification.

    class G1ParVerifyTask: public AbstractGangTask {

使われ方(Usage)

G1CollectedHeap::verify() 内で(のみ)使用されている.

詳細(Details)

See: here for details


PrintRegionClosure

概要(Summary)

デバッグ用(開発時用)のクラス(??) (#ifdef ASSERT 時にしか使用されない? #TODO).

処理対象の HeapRegion の情報を出力する Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class PrintRegionClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::print_on_extended() 内で(のみ)使用されている. そして, この関数は現在は以下のパスで(のみ)呼び出されている.

G1CollectedHeap::print_on()
-> G1CollectedHeap::print_on_extended()

詳細(Details)

See: here for details


VerifyMarkedObjsClosure

概要(Summary)

トラブルシューティング用のクラス (関連する diagnostic オプションが指定されている場合にのみ使用される) (See: VerifyDuringGC).

Concurrent Marking 処理の結果が正しいことをチェックするための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class VerifyMarkedObjsClosure: public ObjectClosure {

使われ方(Usage)

G1CollectedHeap::checkConcurrentMark() 内で(のみ)使用されている.

詳細(Details)

See: here for details


FindGCAllocRegion

概要(Summary)

デバッグ用(開発時用)のクラス (#ifdef G1_DEBUG 時にしか定義されない).

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    #ifdef G1_DEBUG
    class FindGCAllocRegion: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::forget_alloc_region_list() 内で(のみ)使用されている.

詳細(Details)

See: here for details


G1IsAliveClosure

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される Closure クラス (See: here for details).

参照オブジェクト(java.lang.ref オブジェクト)の処理に用いられる Closure クラス. G1IsAliveClosure::do_object_b() メソッドが呼ばれると, 処理対象のオブジェクトが生きているかどうかを返す.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class G1IsAliveClosure: public BoolObjectClosure {

使われ方(Usage)

G1CollectedHeap::evacuate_collection_set() 内で(のみ)使用されている.

詳細(Details)

See: here for details


G1KeepAliveClosure

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される Closure クラス (See: here for details).

参照オブジェクト(java.lang.ref オブジェクト)に対する処理に用いられる Closure クラス. まだコピーされていないオブジェクトに対して, コピー処理を行い, さらに元の場所にフォワーディングポインタを埋める処理を行う.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class G1KeepAliveClosure: public OopClosure {

使われ方(Usage)

G1CollectedHeap::evacuate_collection_set() 内で(のみ)使用されている.

詳細(Details)

See: here for details


UpdateRSetDeferred

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される Closure クラス (See: here for details).

Minor GC がメモリ不足で失敗した場合に, コピーできなかったオブジェクトについて, Remembered Set 情報を作成し直す.

なお, このクラスは develop オプションである G1DeferredRSUpdate が変更されていない場合(= true の場合)に使用される. G1DeferredRSUpdate オプションが false の場合には, 代わりに UpdateRSetImmediate クラスが使用される.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class UpdateRSetDeferred : public OopsInHeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::remove_self_forwarding_pointers() 内で(のみ)使用されている.

詳細(Details)

See: here for details


RemoveSelfPointerClosure

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される Closure クラス (See: here for details).

Minor GC がメモリ不足で失敗した場合に, コピーできなかったオブジェクトについて, markbit や Remembered Set 情報を作成し直す.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class RemoveSelfPointerClosure: public ObjectClosure {

使われ方(Usage)

G1CollectedHeap::remove_self_forwarding_pointers() 内で(のみ)使用されている.

詳細(Details)

See: here for details


G1ParEvacuateFollowersClosure

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される Closure クラス (See: here for details).

処理したオブジェクトから辿れる範囲全てについて再帰的に処理を行う.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class G1ParEvacuateFollowersClosure : public VoidClosure {

使われ方(Usage)

G1ParTask::work() 内で(のみ)使用されている.

詳細(Details)

See: here for details


G1ParTask

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される補助クラス (See: here for details).

実際の Minor GC 処理("Evacuation Pause" 処理) を行う AbstractGangTask クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class G1ParTask : public AbstractGangTask {

使われ方(Usage)

G1CollectedHeap::evacuate_collection_set() 内で(のみ)使用されている.

詳細(Details)

See: here for details


SaveMarksClosure

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される Closure クラス (See: here for details).

(Minor GC の処理前に) 全ての HeapRegion の top 位置を記録しておく(save_marks)ための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class SaveMarksClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::save_marks() 内で(のみ)使用されている. そして, この関数は現在は以下のパスで(のみ)呼び出されている.

G1CollectedHeap::do_collection_pause_at_safepoint()
-> G1CollectedHeap::save_marks()

詳細(Details)

See: here for details


G1ParCleanupCTTask

概要(Summary)

G1CollectedHeap の Minor GC 処理("Evacuation Pause" 処理)で使用される補助クラス (See: here for details).

(Minor GC の処理後に) Collection Set 中の HeapRegion の中で Barrier Set をクリアする必要があるもの (= CollectedHeap::_dirty_cards_region_list 内の HeapRegion) に対し, クリア処理を行う.

(ついでに, Survivor として使われている HeapRegion の Barrier Set を dirty 化する処理も行っている).

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class G1ParCleanupCTTask : public AbstractGangTask {

使われ方(Usage)

G1CollectedHeap::cleanUpCardTable() 内で(のみ)使用されている. そして, この関数は現在は以下のパスで(のみ)呼び出されている.

G1CollectedHeap::evacuate_collection_set()
-> G1RemSet::cleanup_after_oops_into_collection_set_do()
   -> G1CollectedHeap::cleanUpCardTable()

詳細(Details)

See: here for details


G1VerifyCardTableCleanup

概要(Summary)

デバッグ用(開発時用)のクラス (#ifndef PRODUCT 時にしか定義されない).

(Minor GC の処理後に) 以下が成り立っていることをチェックする.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    #ifndef PRODUCT
    class G1VerifyCardTableCleanup: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::cleanUpCardTable() 内で(のみ)使用されている.

詳細(Details)

See: here for details


NoYoungRegionsClosure

概要(Summary)

デバッグ用(開発時用)のクラス (#ifdef ASSERT 時にしか使用されない).

処理対象の HeapRegion が New 領域に含まれていない(= HeapRegion::_young_type が NotYoung である)ことをチェックする.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class NoYoungRegionsClosure: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::check_young_list_empty() 内で(のみ)使用されている. そして, この関数は現在は以下のパスで(のみ)呼び出されている (ただし, どちらも assert() 内でしか使用されていない).

* Minor GC 処理
  G1CollectedHeap::do_collection_pause_at_safepoint()
  -> G1CollectedHeap::check_young_list_empty()

* Major GC 処理
  G1CollectedHeap::do_collection()
  -> G1CollectedHeap::check_young_list_empty()

詳細(Details)

See: here for details


RegionResetter

概要(Summary)

G1CollectedHeap の処理で使用される補助クラス.

(ヒープの縮小時や Major GC の処理後に) MasterFreeRegionList や MasterHumongousRegionSet を再構築するための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    class RegionResetter: public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::rebuild_region_lists() 内で(のみ)使用されている.

詳細(Details)

See: here for details


VerifyRegionListsClosure

概要(Summary)

デバッグ用(開発時用)のクラス.

MasterFreeRegionList や MasterHumongousRegionSet が正しい状態になっていることをチェックするための Closure クラス.

    ((cite: hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp))
    // Heap region set verification

    class VerifyRegionListsClosure : public HeapRegionClosure {

使われ方(Usage)

G1CollectedHeap::verify_region_sets() 内で(のみ)使用されている. そして, この関数は現在は以下のパスで(のみ)呼び出されている.

* 
  G1CollectedHeap::verify()
  -> G1CollectedHeap::verify_region_sets()

* 
  G1CollectedHeap::verify_region_sets_optional()
  -> G1CollectedHeap::verify_region_sets()   (<= ただし #ifdef HEAP_REGION_SET_FORCE_VERIFY 時にしか呼び出されない)

備考(Notes)

HEAP_REGION_SET_FORCE_VERIFY は, デフォルトだと #ifdef ASSERT 時にのみ定義される (このため #ifdef HEAP_REGION_SET_FORCE_VERIFY は #ifdef ASSERT と同義).

    ((cite: hotspot/src/share/vm/gc_implementation/g1/heapRegionSet.hpp))
    // Set verification will be forced either if someone defines
    // HEAP_REGION_SET_FORCE_VERIFY to be 1, or in builds in which
    // asserts are compiled in.
    #ifndef HEAP_REGION_SET_FORCE_VERIFY
    #define HEAP_REGION_SET_FORCE_VERIFY defined(ASSERT)
    #endif // HEAP_REGION_SET_FORCE_VERIFY

詳細(Details)

See: here for details



This document is available under the GNU GENERAL PUBLIC LICENSE Version 2.