如果您有充分的理由相信大量对象(尤其是您怀疑属于第1代和第2代的对象)现在可以进行垃圾收集了,那么就性能损失较小而言,现在是适当的收集时间。
一个很好的例子是,如果您刚刚关闭了一个大表格。您知道现在可以对所有UI控件进行垃圾收集,并且由于关闭表单而造成的短暂暂停可能对用户而言并不明显。
更新2.7.2018
从.NET 4.5开始-
GCLatencyMode.LowLatency和
GCLatencyMode.SustainedLowLatency。进入和退出这两种模式时,建议您使用强制使用完整的GC
GC.Collect(2, GCCollectionMode.Forced)。
从.NET 4.6开始-
有一种
GC.TryStartNoGCRegion方法(用于设置只读值
GCLatencyMode.NoGCRegion)。这本身可以执行完整的阻塞垃圾回收,以释放足够的内存,但是鉴于我们在一段时间内不允许使用GC,因此我认为在此之前和之后执行完整的GC同样是一个好主意。
资料来源:微软工程师本·沃森(Ben Watson): 编写高性能.NET代码 ,第二版。2018。
看到:
- https://msdn.microsoft.com/zh-cn/library/system.runtime.gclatencymode(v=vs.110).aspx
- https://msdn.microsoft.com/zh-CN/library/dn906204(v=vs.110).aspx



