您好,登录后才能下订单哦!
在Java中,线程是程序执行的最小单元,线程的状态反映了线程在其生命周期中的不同阶段。了解线程的状态对于编写高效、稳定的多线程程序至关重要。本文将详细介绍Java中的线程状态,包括每种状态的定义、转换条件以及相关的代码示例。
Java中的线程状态由java.lang.Thread.State
枚举类定义,共有六种状态:
这些状态描述了线程在其生命周期中的不同阶段。下面我们将逐一介绍每种状态。
当一个线程对象被创建但尚未启动时,它处于NEW
状态。此时,线程还没有开始执行,也没有分配任何系统资源。
Thread thread = new Thread(() -> {
System.out.println("Thread is running");
});
System.out.println("Thread state: " + thread.getState()); // 输出: Thread state: NEW
start()
方法后,线程从NEW
状态转换为RUNNABLE
状态。当线程调用start()
方法后,线程进入RUNNABLE
状态。此时,线程已经准备好运行,但可能还没有真正开始执行,具体取决于操作系统的调度。
Thread thread = new Thread(() -> {
System.out.println("Thread is running");
});
thread.start();
System.out.println("Thread state: " + thread.getState()); // 输出: Thread state: RUNNABLE
BLOCKED
状态。Object.wait()
、Thread.join()
或LockSupport.park()
方法,线程将进入WTING
状态。Thread.sleep(long millis)
、Object.wait(long timeout)
、Thread.join(long millis)
或LockSupport.parkNanos(long nanos)
等方法,线程将进入TIMED_WTING
状态。TERMINATED
状态。当线程尝试获取一个对象的锁,但该锁已被其他线程持有时,线程将进入BLOCKED
状态。此时,线程无法继续执行,直到锁被释放。
Object lock = new Object();
Thread thread1 = new Thread(() -> {
synchronized (lock) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
Thread thread2 = new Thread(() -> {
synchronized (lock) {
System.out.println("Thread2 acquired the lock");
}
});
thread1.start();
thread2.start();
Thread.sleep(500); // 确保thread1先获取锁
System.out.println("Thread2 state: " + thread2.getState()); // 输出: Thread2 state: BLOCKED
RUNNABLE
状态,等待CPU调度。当线程调用了Object.wait()
、Thread.join()
或LockSupport.park()
方法时,线程将进入WTING
状态。此时,线程将无限期地等待,直到其他线程唤醒它。
Object lock = new Object();
Thread thread = new Thread(() -> {
synchronized (lock) {
try {
lock.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
thread.start();
Thread.sleep(500); // 确保线程进入WTING状态
System.out.println("Thread state: " + thread.getState()); // 输出: Thread state: WTING
Object.notify()
或Object.notifyAll()
方法时,线程将被唤醒,重新进入RUNNABLE
状态。当线程调用了Thread.sleep(long millis)
、Object.wait(long timeout)
、Thread.join(long millis)
或LockSupport.parkNanos(long nanos)
等方法时,线程将进入TIMED_WTING
状态。此时,线程将等待指定的时间,或者被其他线程唤醒。
Thread thread = new Thread(() -> {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
});
thread.start();
Thread.sleep(500); // 确保线程进入TIMED_WTING状态
System.out.println("Thread state: " + thread.getState()); // 输出: Thread state: TIMED_WTING
RUNNABLE
状态。当线程执行完毕或因为异常而终止时,线程将进入TERMINATED
状态。此时,线程的生命周期结束,无法再次启动。
Thread thread = new Thread(() -> {
System.out.println("Thread is running");
});
thread.start();
thread.join(); // 等待线程执行完毕
System.out.println("Thread state: " + thread.getState()); // 输出: Thread state: TERMINATED
TERMINATED
状态,就无法再转换到其他状态。为了更直观地理解线程状态的转换,下面是一个线程状态转换图:
NEW -> RUNNABLE -> BLOCKED
| |
v v
WTING <-> TIMED_WTING
|
v
TERMINATED
Java中的线程状态是理解多线程编程的基础。通过了解每种状态的定义、转换条件以及相关的代码示例,我们可以更好地掌握线程的生命周期,从而编写出高效、稳定的多线程程序。在实际开发中,合理管理线程状态,避免死锁、资源竞争等问题,是确保程序正确运行的关键。
通过本文的详细介绍,相信读者对Java中的线程状态有了更深入的理解。在实际开发中,合理管理线程状态,避免死锁、资源竞争等问题,是确保程序正确运行的关键。希望本文能帮助读者在多线程编程中更加得心应手。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。