问题描述
- java 子线程结束结束 内部子线程也结束 具体看代码注释
-
import java.util.ArrayList;import org.junit.Test;
/**
- 代码很简单的 就是起了一个线程 然后在一个list里面放了1000个数字 然后打印以下
- 但是test方法 用junit起的 不能完全打印 而main可以
- 最终是想要使得这个test方法能和main的效果一样
*
*/
public class TestSub {@Test
public void test() {
/**
* 此处是在junit测试下面执行的线程 但是list里面的值不能被完全打印出来
* 我猜想这个方法是在一个子进程里面进行的 而里面又有一个子线程 但是最外层的子线程(test方法)一结束 里面的子线程也全部结束
*/
new Thread(new Runnable() {@Override public void run() { long start = System.currentTimeMillis(); ArrayList<Integer> list = new ArrayList<Integer>(); for (int i = 0; i < 1000; i++) { list.add(i); } for (Integer value : list) { System.out.println("list size : " + list.size() + " current value : " + value); } long end = System.currentTimeMillis(); System.out.println("takes time :" + (end - start)); } }).start(); System.out.println("线程执行结束 test方法执行完毕");
}
/**
- main函数的线程 与 上面测试方法的子线程不同 它执行完方法后 里面的子线程仍旧会执行完毕
- 如何让上面的test方法与main函数执行的结果一样
- @param args
*/
public static void main(String[] args) {new Thread(new Runnable() {
@Override public void run() { long start = System.currentTimeMillis(); ArrayList<Integer> list = new ArrayList<Integer>(); for (int i = 0; i < 1000; i++) { list.add(i); } for (Integer value : list) { System.out.println("list size : " + list.size() + " current value : " + value); } long end = System.currentTimeMillis(); System.out.println("takes time :" + (end - start)); }
}).start();
System.out.println("主线程执行结束 main方法执行完毕");
}
}
解决方案
去看下thread相关的文档
解决方案二:
我猜想这个方法是在一个子进程里面进行的 而里面又有一个子线程 但是最外层的子线程(test方法)一结束 里面的子线程也全部结束
你分析的应该很有道理,我觉得应该是java的垃圾回收机制引起的,当test执行完成后java会进行自动的垃圾回收,把里面的子线程给结束了
你可以在子线程里
System.out.println("线程执行结束 test方法执行完毕");
前先执行线程同步,保证线程执行完成再向后执行最后的语句
解决方案三:
ok,我给你答案但是不给出原因,你自己去找答案
Thread t = new Thread(new Runnable() {
@Override
public void run() {
long start = System.currentTimeMillis();
ArrayList list = new ArrayList();
for (int i = 0; i < 1000; i++) {
list.add(i);
}
for (Integer value : list) {
System.out.println("list size : " + list.size() + " current value : " + value);
}
long end = System.currentTimeMillis();
System.out.println("takes time :" + (end - start));
}
});
t.start();
t.join();
System.out.println("主线程执行结束 main方法执行完毕");
解决方案四:
你加上一个状态字段来控制线程是否运行结束,然后在进程中进行判断,如果线程结束,手工控制进行结束;如果线程为运行结束,在进程中等待;
在进程中定义flag为false,传递给线程,线程结束,置为true,在进程中循环判断flag为true,退出进程。
解决方案五:
找到原因了 这是junit本身测试多线程的不足