We have a WPF application, based on Unity with MMVVVM pattern. In application life cycle there can be several project life cycles, after each project life cycle we do a manual Tear Down and try to free all the reference of ViewModels. For event subscriptions with Unity we are using Weak references. So we are assuming that after tear down, we may call GC Collect, so that all the garbage objects are garbage collected. We have another option of manually un-subscribing all the events, but we are preferring garbage collection because it will clear around 200MB for us, which will facilitate new project loading.
With one instance, we are observing that, If i call GC.Collect only one time, its reference still remains in memory for sometime.
GC.Collect();
GC.WaitForPendingFinalizers();
But if i try Calling GC twice in a row, its cleans up everything nicely.
GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();
GC.WaitForPendingFinalizers();
Any thoughts or pointers will be highly appreciated.
Update:
There are no Finalizers defined in Class.
Now i am also considering a case, in which this object is referred in another object which might have a finalizer. In Our framework, we have finalizer only for DBProvider, so i don't think, even this is the case.