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方法执行完毕");
}
}