首页 / 知识

关于.net:是什么阻止了C#中的线程被收集?

2023-04-16 11:57:00

关于.net:是什么阻止了C#中的线程被收集?

What prevents a Thread in C# from being Collected?

在.NET中,此代码之后,什么机制阻止Thread对象被垃圾回收?

1
2
new Thread(Foo).Start();
GC.Collect();

是的,可以安全地假设某些东西引用了该线程,我只是在徘徊什么。 由于某些原因,Reflector不会向我显示System.Threading,所以我自己也无法对此进行挖掘(我知道MS发布了.NET框架的源代码,只是没有用)。


只要线程正在运行,运行时就会保留对该线程的引用。只要有人仍然保留该参考,GC就不会收集它。


这取决于线程是否正在运行。如果您只是创建了Thread对象而没有启动它,则它是一个普通的托管对象,即有资格使用GC。一旦启动线程,或者为已经运行的线程(GetCurrentThread)获取Thread对象,就会有些不同。现在,"暴露对象"(托管线程)在CLR中保持强引用,因此您始终会获得相同的实例。当线程终止时,将释放此强引用,并且在您没有对Thread的其他任何引用(现已死亡)时,将立即收集托管对象。


这是垃圾收集器的硬连线功能。不收集正在运行的线程。


但是要注意的重要一点-如果您的线程标记为IsBackground = True,则不会阻止整个进程退出


好吧,可以肯定地假设,如果某个线程正在某个有引用的地方运行,那足以阻止垃圾回收吗?


将新线程分配给本地字段?

1
2
3
4
5
6
7
8
9
10
11
class YourClass
{
  Thread thread;

  void Start()
  {
    thread = new Thread(Foo);
    thread.Start();
    GC.Collect();
  }
}

垃圾回收会收集不是引用的所有内容,因此在您的代码中,没有字段/变量引用该线程,因此将对其进行收集。


线程垃圾回收对象机制

最新内容

相关内容

猜你喜欢