Generations
The heap is organized into
generations so it can handle long-lived and short-lived objects. Garbage
collection primarily occurs with the reclamation of short-lived objects
that typically occupy only a small part of the heap. There are three
generations of objects on the heap:
-
Generation 0. This is the youngest
generation and contains short-lived objects. An example of a short-lived
object is a temporary variable. Garbage collection occurs most
frequently in this generation.
Newly allocated objects form a new generation of objects and are implicitly generation 0 collections, unless they are large objects, in which case they go on the large object heap in a generation 2 collection.
Most objects are reclaimed for garbage collection in generation 0 and do not survive to the next generation.
-
Generation 1. This generation contains short-lived objects and serves as a buffer between short-lived objects and long-lived objects.
-
Generation 2. This generation contains
long-lived objects. An example of a long-lived object is an object in a
server application that contains static data that is live for the
duration of the process.
Garbage collections occur on
specific generations as conditions warrant. Collecting a generation
means collecting objects in that generation and all its younger
generations. A generation 2 garbage collection is also known as a full
garbage collection, because it reclaims all objects in all generations
(that is, all objects in the managed heap).
How does Garbage collector locate garbage
When an program is loaded in the memory there will be a bunch of memory allocated for that particular program alone and loaded with the memory. This bunch of memory is called Managed Heap in .NET world. This amount of memory will only be used when an object is to be loaded in to the memory for that particular program.
This memory is separated in to three parts :
When an program is loaded in the memory there will be a bunch of memory allocated for that particular program alone and loaded with the memory. This bunch of memory is called Managed Heap in .NET world. This amount of memory will only be used when an object is to be loaded in to the memory for that particular program.
This memory is separated in to three parts :
- Generation Zero
- Generation One
- Generation Two
When we try to create an object by using NEW keyword the system will,
- Calculate the number of bytes required for the object or type to be loaded in to the managed heap.
- The
CLR then checks that the bytes required to allocate the object are
available in the reserved region (committing storage if necessary). IF
the object fits, it is allocated at the address pointed to by
NextObjPtr
. - These processes will happen at the Generation zero level.
Now the garbage collector will come and check all the objects in the Generation Zero level. If an object's scope and lifetime goes off then the system will automatically mark it for garbage collection.
Note:
Here in the process the object is just marked and not collected. Garbage collector will only collect the object and free the memory.
Garbage collector will come and start examining all the objects in the level Generation Zero right from the beginning. If it finds any object marked for garbage collection, it will simply remove those objects from the memory.
Here comes the important part. Now let us refer the figure below. There are three objects in the managed heap. If A and C are not marked but B has lost it scope and lifetime. So B should be marked for garbage collection. So object B will be collected and the managed heap will look like this.
But do remember that the system will come and allocate the new objects only at the last. It does not see in between. So it is the job of garbage collector to compact the memory structure after collecting the objects. It does that also. So the memory would be looking like as shown below now.
But garbage collector does not come to end after doing this. It will look which are all the objects survive after the sweep (collection). Those objects will be moved to Generation One and now the Generation Zero is empty for filling new objects.
If Generation One does not have space for objects from Generation Zero, then the process happened in Generation Zero will happen in Generation one as well. This is the same case with Generation Two also.
You may have a doubt, all the generations are filled with the referred objects and still system or our program wants to allocate some objects, then what will happen? If so, then the
MemoryOutofRangeException
will be thrown.Reference:http://techiemate.blogspot.in/2009/04/garbage-collection-in-net.html
No comments:
Post a Comment