线程创建后,并不会立刻执行,可是要和其他线程抢占CPU资源。线程从创建到灭亡有七个状态。
首先看不包含其他路径的一个线程状态流转图:
当然,线程的运行并不是一帆风顺的,其中有很多情况需要考虑。下面增加两种情况:sleeping、wait。Sleeping是一种超时等待,时间结束后,继续去争用CPU资源。wait就是一种等待,除非执行notify或notifyAll。
有个这张图后,我们去看代码。
public class NewThread implements Runnable {
@Override
public void run() {
//进入sleeping状态,当时间结束后,自动进入ready to run方法
Thread.sleep(100);
}
public static void main(String[] args) {
//线程创建时,进入初始化状态
Thread t = new Thread(new NewThread());
//执行完start方法后,进入ready to run
t.start();
}
}
下面演示子线程wait状态,主线程notifyAll唤醒它。
public class NewThread implements Runnable {
@Override
public synchronized void run() {
while (true) {
try {
//进入wait状态
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("自定义的线程运行啦!");
}
}
public static void main(String[] args) {
NewThread thread = new NewThread();
Thread t = new Thread(thread);
t.start();
while (true) {
synchronized (thread) {
System.out.println("主线程");
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
thread.notifyAll();
}
}
}
}
执行结果
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
主线程
自定义的线程运行啦!
主线程
主线程
主线程