回顾:
Thread类的activeCount()方法用于返回当前线程的线程组中活动线程的数量。返回的值只是一个估计值,因为当此方法遍历内部数据结构时,线程数可能会动态更改。总之它返回当前线程的线程组中活动线程的数量。
在研究多线程对同一变量的修改时,我们可能会用到类似如下代码:
while(Thread.activeCount()>1){
Thread.yield();
}
System.out.println("result: "+结果);
但是在idea下执行的时候,往往得不到结果,在使用java命令行执行或者eclipse执行却没有这个问题。
(1)以run模式启动输出时
经过测试发现,原来在执行main方法时,idea会启动两条线程,测试如下:
public class TestIdea {
public static void main(String[] args) {
System.out.println("activeCount:"+Thread.activeCount());
Thread.currentThread().getThreadGroup().list();
}
}
可以发现:
并且尝试以不同模式运行时,竟然输出不一样。以run模式启动输出时,除了main方法的主线程外还有,还多了一个预期外的 Monitor Ctrl-Break 线程。
所以在判断线程执行完的条件改为活跃线程数 >2 就行了
(2)以debug模式启动输出时
(3)Centos7云服务器上启动运行
jdk版本1.8,环境InteliJ IDEA
进一步分析该问题:将环境切换至单核的Centos7云服务器上,编译,执行。
总结:
(1)以run方式启动时,执行用户程序之前,会用反射方式在当前线程的线程组之中又开了一个Ctrl Break的Monitor的Socket线程,去做监听。
(2)以debug模式启动时,执行用户程序之前,只会开启一个线程。
(3)在Centos7云服务器上启动运行时,Monitor Ctrl-Break 线程消失,此时只会开启一个线程。