Java并发编程 | 第一篇:线程基础

「爱情、让人受尽委屈。」 2022-03-19 10:52 350阅读 0赞

线程介绍

JAVA程序其实天生就是多线程,执行一个最简单的main方法,就至少有5个线程被创建。

  1. public static void main(String[] args) {
  2. //获取JAVA虚拟机线程管理MXBean
  3. ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
  4. //不需要获取同步的Monitor和Synchronizer信息,仅获取线程和线程堆栈信息
  5. ThreadInfo[] threadInfos = threadMXBean.dumpAllThreads(false, false);
  6. //遍历线程信息,打印线程ID和线程名称
  7. for (ThreadInfo threadInfo : threadInfos) {
  8. System.out.println("[" + threadInfo.getThreadId() + "]" + " " + threadInfo.getThreadName());
  9. }
  10. //获取当前活动线程数及列表
  11. System.out.println("当前活动线程数:" + Thread.activeCount());
  12. Thread.currentThread().getThreadGroup().list();
  13. }

执行结果如下:
在这里插入图片描述
由此可见,除了main执行函数外,还有其他线程同时被创建;另外在IntelliJ IDEA中执行,会多一个线程,[6] Monitor Ctrl-Break,如下图:
在这里插入图片描述
[6] Monitor Ctrl-Break
IntelliJ IDEA执行代码的时候,实际是通过反射方式去调用,而与此同时会创建一个Monitor Ctrl-Break 用于监控目的。

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

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

[3] 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线程来说是一种灾难;

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

[1] main:
主线程,用户执行程序的入口。

发表评论

表情:
评论列表 (有 0 条评论,350人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Java并发编程线

    前言 你是否曾经遇到过这样的情况:当你在开发一个多线程应用程序时,你需要同时创建许多线程来完成不同的任务,但是你很快就发现,线程数量太多会导致程序的性能下降,甚至会导致程

    相关 并发编程-Java线基础

    基础概念 程序、进程和线程 > 程序是指指令和数据的集合。 > > 指令在CPU上执行。数据需要被加载到内存中。指令执行用到数据时,需要从内存中读取并拷贝对应数据