Java 线程是 Java 平台提供的一个非常重要的多线程编程工具,Java 线程的状态也决定了它在运行过程中的行为以及能够执行的操作。在本文中,我们将讨论 Java 线程的几种状态,以及在每种状态下可以执行的操作。
Java 线程的状态
Java 线程有以下 6 种状态:
- New(新创建)
- Runnable(可运行)
- Blocked(阻塞)
- Waiting(等待)
- Timed Waiting(定时等待)
- Terminated(结束)
下面我们将逐一介绍每种状态以及相应的操作。
New(新创建)
当我们使用 new 操作符创建一个线程对象时,该线程处于 New 状态。在这种状态下,线程对象已经被创建,但是还没有被启动。在这个状态下,线程对象还没有和 CPU 时间片关联起来,也就是说,它还没有执行 run() 方法。
下面是一个示例代码:
public class NewThread extends Thread {
public void run() {
System.out.println("New Thread");
}
public static void main(String[] args) {
NewThread thread = new NewThread();
System.out.println("Thread State: " + thread.getState());
}
}
在这个例子中,我们创建了一个 NewThread 对象,并输出了该对象的状态。在这个状态下,线程处于新创建状态,因此输出结果为:
Thread State: NEW
Runnable(可运行)
在 Runnable 状态下,线程已经被启动,且已经和 CPU 时间片关联起来,可以被操作系统调度执行。当线程处于 Runnable 状态时,它可能正在执行,也可能正等待着 CPU 时间片来执行。
下面是一个示例代码:
java
public class RunnableThread implements Runnable {
public void run() {
System.out.println("Runnable Thread");
}
public static void main(String[] args) {
Thread thread = new Thread(new RunnableThread());
thread.start();
System.out.println("Thread State: " + thread.getState());
}
}
在这个例子中,我们创建了一个 RunnableThread 对象,并将其传递给 Thread 构造函数,创建了一个线程对象。在启动线程后,我们输出了该线程的状态。在这个状态下,线程处于可运行状态,因此输出结果为:
Thread State: RUNNABLE
Blocked(阻塞)
在 Blocked 状态下,线程正在等待获取一个内部锁,而该锁已经被其他线程占用。当线程处于 Blocked 状态时,它处于非活动状态,不会消耗 CPU 时间片。
下面是一个示例代码:
java
public class BlockedThread extends Thread {
public synchronized void run() {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {}
}
public static void main(String[] args) {
BlockedThread thread1 = new BlockedThread();
BlockedThread thread2 = new BlockedThread();
thread1.start();
thread2.start();
System.out.println("Thread 1 State: " + thread1.getState());
System.out.println("Thread 2 State: " + thread2.getState());
}
}
在这个例子中,我们创建了两个 BlockedThread 对象,并在每个对象的 run() 方法上使用 synchronized 关键字来获取内部锁。在启动两个线程后,我们输出了每个线程的状态。在这个状态下,线程处于阻塞状态,因此输出结果为:
Thread 1 State: BLOCKED
Thread 2 State: BLOCKED
Waiting(等待)
在 Waiting 状态下,线程正在等待另一个线程通知它一个条件,或等待一段时间。当线程处于 Waiting 状态时,它处于非活动状态,不会消耗 CPU 时间片。
下面是一个示例代码:
java
public class WaitingThread extends Thread {
public synchronized void run() {
try {
wait();
} catch (InterruptedException e) {}
}
public static void main(String[] args) {
WaitingThread thread = new WaitingThread();
thread.start();
System.out.println("Thread State: " + thread.getState());
}
}
在这个例子中,我们创建了一个 WaitingThread 对象,并在其 run() 方法上使用 wait() 方法来使线程等待。在启动线程后,我们输出了该线程的状态。在这个状态下,线程处于等待状态,因此输出结果为:
Thread State: WAITING
Timed Waiting(定时等待)
在 Timed Waiting 状态下,线程正在等待另一个线程通知它一个条件,或等待一段时间。与 Waiting 状态不同的是,Timed Waiting 状态下的线程会等待一段时间后自动唤醒。当线程处于 Timed Waiting 状态时,它处于非活动状态,不会消耗 CPU 时间片。
下面是一个示例代码:
java
public class TimedWaitingThread extends Thread {
public synchronized void run() {
try {
wait(1000);
} catch (InterruptedException e) {}
}
public static void main(String[] args) {
TimedWaitingThread thread = new TimedWaitingThread();
thread.start();
System.out.println("Thread State: " + thread.getState());
}
}
在这个例子中,我们创建了一个 TimedWaitingThread 对象,并在其 run() 方法上使用 wait() 方法来使线程等待一段时间后自动唤醒。在启动线程后,我们输出了该线程的状态。在这个状态下,线程处于定时等待状态,因此输出结果为:
Thread State: TIMED_WAITING
Terminated(结束)
当线程执行完毕或者因为异常而结束时,线程处于 Terminated 状态。在这个状态下,线程已经不再活动,不会消耗 CPU 时间片。
下面是一个示例代码:
java
public class TerminatedThread extends Thread {
public void run() {
System.out.println("Terminated Thread");
}
public static void main(String[] args) {
TerminatedThread thread = new TerminatedThread();
thread.start();
while(thread.isAlive()) {}
System.out.println("Thread State: " + thread.getState());
}
}
在这个例子中,我们创建了一个 TerminatedThread 对象,并在其 run() 方法中输出一条消息。在启动线程后,我们使用 while 循环等待线程结束后输出该线程的状态。在这个状态下,线程处于结束状态,因此输出结果为:
Terminated Thread
Thread State: TERMINATED
总结
Java 线程的状态决定了它在运行时能够执行的操作以及行为。在本文中,我们介绍了 Java 线程的 6 种状态,并分别给出了每种状态下的示例代码。熟练地掌握 Java 线程的状态对于编写高效、可靠的多线程应用程序非常重要。