https://www.cnblogs.com/yiwangzhibujian/p/6212104.htmlhtml
http://www.cnblogs.com/hvicen/p/6218981.htmljava
import java.lang.management.ManagementFactory; import java.lang.management.ThreadInfo; import java.lang.management.ThreadMXBean; public class MultiThread { public static void main(String[] args) { // 获取 Java 线程管理 MXBean ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean(); //不须要获取同步的 monitor 和 synchronizer 信息,仅获取线程和线程堆栈信息 ThreadInfo[] threadInfos = threadMXBean.dumpAllThreads(false, false); //遍历线程信息,仅打印线程id和线程名称信息 for (ThreadInfo threadInfo : threadInfos) { System.out.println("[" + threadInfo.getThreadId() + "] " + threadInfo.getThreadName()); } } }
[8] JDWP Command Reader数组
[7] JDWP Event Helper Thread多线程
[6] JDWP Transport Listener: dt_socketsocket
[5] Attach Listenerspa
[4] Signal Dispatcher线程
[3] Finalizercode
[2] Reference Handlerhtm
[1] main对象
线程管理类,经过此类能够获取线程信息数组。
管理工厂类,能够获取线程管理类对象ThreadMXBean。
从打印结果能够看出,虽然面上只看到main线程,可是实际上Java程序中启动了不少线程。
以上还都是默认的系统线程,若是代码中有用户本身建立的Thread,那么将会有更多的线程。
用户主线程的入口是main()静态方法,子线程的入口是Thread的run()方法。
public class ThreadGroupDemo { public static void main(String[] args) { Thread thread1 = new Thread("my thread1") { public void run() { Object lock = new Object(); synchronized(lock){ try { lock.wait(); } catch (InterruptedException e) { // e.printStackTrace(); } } } }; thread1.start(); Thread thread2 = new Thread(new ThreadGroup("my group"), "my thread2") { public void run() { Object lock = new Object(); synchronized(lock){ try { lock.wait(); } catch (InterruptedException e) { // e.printStackTrace(); } } } }; thread2.start(); ThreadGroup group = Thread.currentThread().getThreadGroup(); while (group.getParent() != null) group = group.getParent(); group.list(); thread1.interrupt(); thread2.interrupt(); } }
java.lang.ThreadGroup[name=system,maxpri=10]
Thread[Reference Handler,10,system]
Thread[Finalizer,8,system]
Thread[Signal Dispatcher,9,system]
Thread[Attach Listener,5,system]
java.lang.ThreadGroup[name=main,maxpri=10]
Thread[main,5,main]
Thread[Monitor Ctrl-Break,5,main]
Thread[my thread1,5,main]
java.lang.ThreadGroup[name=my group,maxpri=10]
Thread[my thread2,5,my group]
其实能够看出来,ThreadGroup是有层级关系的。main线程所在的ThreadGroup是在名为system的ThreadGroup下面的。
线程分组ThreadGroup,是一个线程集合,同时也是一个树节点,至关于文件夹,里面能够存放文件和子文件夹。
名为main的ThreadGroup就在名为system的ThreadGroup下面。或者能够认为名为main的ThreadGroup是名为system的ThreadGroup的【子文件夹】。同理,名为my group的ThreadGroup能够认为是名为main的ThreadGroup的【子文件夹】。
运行结果的分组与线程信息以下图所示:
system分组就是一个根线程组,其下就是main分组,main分组就是包含主线程的分组。
线程在建立时,能够选择提供线程组,未提供时就会使用默认的线程组,默认线程组的提供策略由SecurityManager#getThreadGroup()决定,而默认的提供策略为建立时当前线程所属的线程组。
打印出根线程组下的线程和子线程组信息。