import java.util.ArrayList;
import org.junit.Test;
/**
最终是想要使得这个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方法执行完毕");
}
/**
@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方法执行完毕");
}
}
我猜想这个方法是在一个子进程里面进行的 而里面又有一个子线程 但是最外层的子线程(test方法)一结束 里面的子线程也全部结束
你分析的应该很有道理,我觉得应该是java的垃圾回收机制引起的,当test执行完成后java会进行自动的垃圾回收,把里面的子线程给结束了
你可以在子线程里
System.out.println("线程执行结束 test方法执行完毕");
前先执行线程同步,保证线程执行完成再向后执行最后的语句
去看下thread相关的文档
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本身测试多线程的不足