线程到底什么时候启动呢?
有时候子线程马上就启动了,有时候在主线程执行了好多行代码之后子线程还三三两两的来启动几个。。。
按我的测试对子线程的启动有了一定认识,但我仍然觉得认识很肤浅,希望看到更深入的见解
/**
* 测试线程什么时候启动。
* 我的观点:
* 1、调用线程的start()方法之后,就把线程放在等待队列之中,等待获得CPU时间片执行,
* 但等待队列中的线程获得CPU时间并没有绝对的先后顺序,谁抢到了CPU,谁就先执行。
* 2、如果在主线程中创建好了子线程之后,此时此刻我想让它们全部启动,我们就让主线程sleep(),
* 睡眠的时间根据你估计所有的子线程启动需要的时间。如果只有简单的顺序执行代码的话,睡眠100毫秒就够了。
* @author ayis
*
* Nov 29, 2008
*/
public class TestThreadWhenStart {
public static void main(String args[]){
try {
System.out.println("测试开始!");
testThreadStart();
// 主线程睡眠足够长时间,让其它的线程都启动
Thread.sleep(100);
System.out.println("测试结束!");
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 启动5个子线程
*/
public static void testThreadStart(){
for(int i=0 ; i< 5 ; i++){
final int j=i;
new Thread(
new Runnable(){
public void run(){
System.out.println("线程: "+j+" 已启动!");
}
}
).start();
}
}
}
输出的结果是:
测试开始!
线程: 0 已启动!
线程: 2 已启动!
线程: 4 已启动!
线程: 1 已启动!
线程: 3 已启动!
测试结束!
如果注释掉Thread.sleep(100),再次执行,就出现这样的结果:
测试开始!
线程: 0 已启动!
线程: 2 已启动!
线程: 1 已启动!
测试结束!
线程: 3 已启动!
线程: 4 已启动!
有子线程在主线程结束之后才启动。如果让主线程睡眠一下,再执行,(就是代码中的情况),就能保证在子线程都启动后,主线程才继续执行。
正是上面所说的很肤浅,大家多批评批评