Java多线程 线程组原理及实例详解
作者:慢慢来 时间:2022-11-26 02:51:40
线程组
线程组可以批量管理线程和线程组对象。
一级关联
例子如下,建立一级关联。
public class MyThread43 implements Runnable{
public void run()
{
try
{
while (!Thread.currentThread().isInterrupted())
{
System.out.println("ThreadName = " + Thread.currentThread().getName());
Thread.sleep(3000);
}
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
public static void main(String[] args)
{
MyThread43 mt0 = new MyThread43();
MyThread43 mt1 = new MyThread43();
ThreadGroup tg = new ThreadGroup("新建线程组1");
Thread t0 = new Thread(tg, mt0);
Thread t1 = new Thread(tg, mt1);
t0.start();
t1.start();
System.out.println("活动的线程数为:" + tg.activeCount());
System.out.println("线程组的名称为:" + tg.getName());
}
}
输出结果如下
活动的线程数为:2
线程组的名称为:新建线程组1
ThreadName = Thread-0
ThreadName = Thread-1
ThreadName = Thread-0
ThreadName = Thread-1
ThreadName = Thread-1
ThreadName = Thread-0
ThreadName = Thread-1
ThreadName = Thread-0
······
每隔三秒输出两个线程名称,符合预期。
线程组自动归组属性
public class ThreadDomain49 {
public static void main(String[] args) {
System.out.println("A处线程:" + Thread.currentThread().getName() + ", 所属线程:" + Thread.currentThread().getThreadGroup().getName() +
", 组中有线程组数量:" + Thread.currentThread().getThreadGroup().activeGroupCount());
ThreadGroup group = new ThreadGroup("新的组");
System.out.println("B处线程:" + Thread.currentThread().getName() + ", 所属线程:" + Thread.currentThread().getThreadGroup().getName() +
", 组中有线程组数量:" + Thread.currentThread().getThreadGroup().activeGroupCount());
ThreadGroup[] tg = new ThreadGroup[Thread.currentThread().getThreadGroup().activeGroupCount()];
Thread.currentThread().getThreadGroup().enumerate(tg);
for (int i = 0; i < tg.length; i++)
System.out.println("第一个线程组名称为:" + tg[i].getName());
}
}
输出结果如下
A处线程:main, 所属线程:main, 组中有线程组数量:0
B处线程:main, 所属线程:main, 组中有线程组数量:1
第一个线程组名称为:新的组
没有指定线程组,则归属到当前线程所属的组。
根线程组
public class ThreadDomain50 {
public static void main(String[] args)
{
System.out.println(Thread.currentThread().getThreadGroup().getParent().getName());
System.out.println(Thread.currentThread().getThreadGroup().getParent().getParent().getName());
}
}
运行结果
system
Exception in thread "main" java.lang.NullPointerException
at com.advance.MultiThread3.MyThread.ThreadDomain50.main(ThreadDomain50.java:14)
当前线程的线程组的父线程组是系统线程组;系统线程组的父线程组不存在;系统线程组就是根线程组。
批量停止组内线程
请看示例
public class MyThread44 extends Thread{
public MyThread44(ThreadGroup tg, String name)
{
super(tg, name);
}
public void run()
{
System.out.println("ThreadName = " + Thread.currentThread().getName() +
"准备开始死循环了");
while (!this.isInterrupted()){}
System.out.println("ThreadName = " + Thread.currentThread().getName() +
"结束了");
}
public static void main(String[] args) throws InterruptedException {
ThreadGroup tg = new ThreadGroup("我的线程组");
MyThread44 mt = null;
for (int i = 0; i < 3; i++)
{
mt = new MyThread44(tg, "线程" + i);
mt.start();
}
Thread.sleep(5000);
tg.interrupt();
System.out.println("调用了interrupt()方法");
}
}
输出结果如下
ThreadName = 线程0准备开始死循环了
ThreadName = 线程1准备开始死循环了
ThreadName = 线程2准备开始死循环了
调用了interrupt()方法
ThreadName = 线程0结束了
ThreadName = 线程2结束了
ThreadName = 线程1结束了
可以看到,ThreadGroup的interrupt方法批量中断线程组的线程。
来源:https://www.cnblogs.com/Java-Starter/p/11358207.html
标签:java,多,线程,组
0
投稿
猜你喜欢
Java求两集合中元素交集的四种方法对比分析
2023-08-23 09:24:56
Spring Boot全局异常处理解析
2023-07-06 07:16:35
El表达式使用问题javax.el.ELException:Failed to parse the expression的解决方式
2023-11-24 12:47:13
c语言中十六进制转二进制显示的实现方法
2023-12-17 23:21:44
SpringMVC RESTFul实战案例访问首页
2022-03-12 00:21:01
解决idea spring boot 修改html等不重启即时生效的问题
2023-11-13 18:37:47
详解Java中的封装、继承、多态
2022-09-24 06:26:23
C#中数组、ArrayList和List三者的区别详解及实例
2023-11-07 03:12:47
java 中二分法查找的应用实例
2021-10-18 08:43:33
Android开发实现模仿微信小窗口功能【Dialog对话框风格窗口】
2022-01-27 10:11:01
Java日期时间操作的方法
2021-12-27 18:36:05
Android Spinner 组件的应用实例
2022-07-12 04:50:13
解决IDEA鼠标点击光标变大问题
2022-12-07 11:52:37
Java简单实现约瑟夫环算法示例
2023-04-04 09:59:41
Java通过Fork/Join优化并行计算
2023-01-27 21:28:36
Java之SpringBoot自定义配置与整合Druid
2022-09-28 06:23:06
Java如何实现树的同构?
2023-11-28 09:55:19
Android编程实现二维码的生成与解析
2021-12-08 23:13:15
SpringBoot 嵌入式web容器的启动原理详解
2021-12-29 23:23:14
c# winform取消右上角关闭按钮的实现方法
2023-05-05 18:56:28