I have read a lot of .NET performance articles that describe Gen1,Gen2 garbage collection and objects surviving the generations.
Why does objects survives the collection?
What is pinning?
Garbage collection primarily occurs with the reclamation of short-lived objects. To optimize the performance of the garbage collector, the managed heap is divided into three generations, 0, 1, and 2, so it can handle long-lived and short-lived objects separately.
. NET's garbage collector manages the allocation and release of memory for your application. Each time you create a new object, the common language runtime allocates memory for the object from the managed heap.
The Garbage collection algorithm collects all unused objects that are dead objects in the generation. If the live objects running for long time then based on that life time it will be moved to next generation.
Creation of object 11 causes the GC to start again which may move some more objects to generation 1. Generation 1 is ignored for Garbage Collection until it reaches its budget size for Garbage collection, which improves the performance of GC.
One reason you have multiple generations in a garbage collector is to avoid losing memory to fragmentation.
Every function call can mean the creation and deletion collection of multiple objects, and so the memory heap for your program tends to fragment very quickly.  This leaves holes behind that aren't very usable.  The result is that your program needs to be periodically de-fragmented, just like a hard disk.  This is part of what happens during a collection.
When an object survives a collection, it is moved to a longer-lived generation on the theory that if it survived one collection it will probably survive others. Thus the later generations have less turn-over and don't fragment as much. This means your program spends less time overall juggling things around to clean up holes and wastes less memory. This is also an improvement over traditional memory management (malloc/free or new/delete), which left it up to the operating system to manage any memory fragmentation.
The reason an object survives collection is because there is something somewhere that is still "in scope" and holds a reference to that object. There are a few ways you can cause this to happen and then forget about the reference, so it is possible to "leak" memory in managed code.
Sometimes people are tempted to call GC.Collect() in an effort to get the garbage collector to clean something up.  Perhaps they've discovered they have a leak, or think memory is becoming over-fragmented.  You should resist those urges.  While garbage collection in .Net is not perfect, is it very good, and it's almost certainly much better at cleaning up memory than you are.  Odds are that if an object can and should be collected, it will be.  Remember that calling GC.Collect() can actually make things worse by helping the garbage collector move objects up to a higher generation, and thus keeping them around for longer than they otherwise would be.
Instead, if you suspect you have a leak, look to your own code for something like a global or static variable that might hold a reference to a lot of other items.  The only time you should call GC.Collect() is when you have information about the nature of the program that is not available to the garbage collector, and that's pretty rare as the GC knows every reference you've created.
"Pinning" is for when you need to pass an object to an unmanaged library. The garbage collector can move an object's physical location in memory, and so you need to "pin" it in one place or the pointer used by the unmanaged library could become invalid. A pinned object cannot be collected, and so you shouldn't pin an object for any longer than necessary.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With