how tha garbage collector know that the object will be
deleted? on which algorithm the garbage collector works?
what is the working principle of garbage collector? How
manay types of garbage collectors r there?



how tha garbage collector know that the object will be deleted? on which algorithm the garbage col..

Answer / abul kalam

An object is eligible for garbage collection when it
determines no more references to the object exists.


Algorithms that are used for garbage collection.

1 – Reference Counting:

Each object has an associated reference count. This count
indicates the number of active references to that object.
If this count is zero, it is garbage and can be recycled.
Whenever the reference is modified, the count is updated.
Once this count is zero, the memory is reclaimed.

2 – Tracing Collectors:

Mostly the standard garbage collectors do not use Reference
Counting. They will use some form of tracing collector’s
algorithms. This algorithm will trace all objects starting
from root until all reachable objects have been examined.

3 – Mark-Sweep collectors:

This is most basic form of collector algorithm. In this
case the collector visits each node starting from root and
marks each node. Once there are no any references, the
collection is complete. The heap is swept and the objects
not marked are reclaimed and returned to free list.

4 – Copying Collectors:

In this case, the heap is divided into equally sized semi
spaces. One with active data and another with unused. Once
the active space fills up, the objects are copied from
active to unused space and the roles are flipped becoming
unused space as active. This has advantages as it examines
only active data. But will have a overhead of copying data
from active to unused space.

5 – Heap Compaction:

In the copying collectors, the set of live objects can be
compacted at the bottom of heap. This improves locality of
reference and eliminates heap fragmentation and greatly
reduces the cost of object allocation which eliminates the
need to maintain free lists or look-aside lists or perform
best-fit or first-fit algorithms and allocating N bytes is
simple to add N to heal pointer.

Is This Answer Correct ?    5 Yes 0 No

Post New Answer

More Core Java Interview Questions

How to retrieve data from database in java using arraylist?

0 Answers  


Can a class be private in java?

0 Answers  


What’s the difference between callable and runnable?

0 Answers  


Explain the difference between jdk, jre, and jvm?

0 Answers  


Can a class be protected in java?

0 Answers  






What are some examples of variable costs?

0 Answers  


Does treeset allow null in java?

0 Answers  


Implementations of set interface?

0 Answers  


What if constructor is protected in java?

0 Answers  


What is the difference between Java Bean and Java Class.?

2 Answers  


How many classes can any class inherit java?

0 Answers  


What is java life cycle?

0 Answers  


Categories