目录
  1. 1. 多线程–启动一个最简单的程序,有多少个线程被创建
    1. 1.1. Attach Listener
    2. 1.2. Signal Dispatcher
    3. 1.3. Finalizer
    4. 1.4. Reference Handler
    5. 1.5. Monitor Ctrl-Break
多线程--启动一个最简单的程序,有多少个线程被创建

多线程–启动一个最简单的程序,有多少个线程被创建

最近在看多线程并发,忽然看到了这个记录下来

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public class Main{

public static void main(String[]args){

ThreadGroup g = Thread.currentThread().getThreadGroup();
while (g != null){
ThreadGroup temp = g.getParent();
if (temp == null){
break;
}
g = temp;
}
System.out.println("active count is :"+ g.activeCount());
Thread[] all = new Thread[g.activeCount()];
g.enumerate(all);
for (Thread t:all) {
System.out.println(t.getName());
}
}
}

这段代码的意思是获取当前线程的线程组中所有活跃的线程,算上自己 main 函数本身一共有六个线程

执行结果:

1
2
3
4
5
6
7
active count is :6
Reference Handler
Finalizer
Signal Dispatcher
Attach Listener
main
Monitor Ctrl-Break

从网上搜集的对各个线程的解释:

Attach Listener

Attach Listener线程是负责接收到外部的命令,而对该命令进行执行的并且吧结果返回给发送者。通常我们会用一些命令去要求jvm给我们一些反 馈信息,如:java -version、jmap、jstack等等。如果该线程在jvm启动的时候没有初始化,那么,则会在用户第一次执行jvm命令时,得到启动。

Signal Dispatcher

前面我们提到第一个Attach Listener线程的职责是接收外部jvm命令,当命令接收成功后,会交给signal dispather线程去进行分发到各个不同的模块处理命令,并且返回处理结果。signal dispather线程也是在第一次接收外部jvm命令时,进行初始化工作。

Finalizer

这个线程也是在main线程之后创建的,其优先级为10,主要用于在垃圾收集前,调用对象的finalize()方法;关于Finalizer线程的几点:

  1. 只有当开始一轮垃圾收集时,才会开始调用finalize()方法;因此并不是所有对象的finalize()方法都会被执行;

  2. 该线程也是daemon线程,因此如果虚拟机中没有其他非daemon线程,不管该线程有没有执行完finalize()方法,JVM也会退出;

  3. JVM在垃圾收集时会将失去引用的对象包装成Finalizer对象(Reference的实现),并放入ReferenceQueue,由Finalizer线程来处理;最后将该Finalizer对象的引用置为null,由垃圾收集器来回收;

  4. JVM为什么要单独用一个线程来执行finalize()方法呢?如果JVM的垃圾收集线程自己来做,很有可能由于在finalize()方法中误操作导致GC线程停止或不可控,这对GC线程来说是一种灾难;

Reference Handler

VM在创建main线程后就创建Reference Handler线程,其优先级最高,为10,它主要用于处理引用对象本身(软引用、弱引用、虚引用)的垃圾回收问题。

Monitor Ctrl-Break

这个线程我也不是很明白是干什么用的,oracle官网有详细信息,大家可以去看看
详细链接

文章作者: Archiver
文章链接: https://www.kaiming66.com/2020/01/26/Java/%E5%A4%9A%E7%BA%BF%E7%A8%8B--%E5%90%AF%E5%8A%A8%E4%B8%80%E4%B8%AA%E6%9C%80%E7%AE%80%E5%8D%95%E7%9A%84%E7%A8%8B%E5%BA%8F%EF%BC%8C%E6%9C%89%E5%A4%9A%E5%B0%91%E4%B8%AA%E7%BA%BF%E7%A8%8B%E8%A2%AB%E5%88%9B%E5%BB%BA/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Archiver`s Blog
打赏
  • 微信
  • 支付寶

评论