博客
关于我
Java线程状态完全解析教程
阅读量:667 次
发布时间:2019-03-15

本文共 2866 字,大约阅读时间需要 9 分钟。

setState 的λης statewide method of Thread class in Java determines the current state of a thread. Thread has six possible states: NEW, RUNNABLE, BLOCKED, WAITING, TIME_WAITING, and TERMINATED. This article explains these states, their transitions, and how to control thread states through Thread APIs.

1. State Definitions

  • NEW: Created thread before calling start()
  • RUNNABLE: Ready to execute (justified as a combination of ready and running states)
  • BLOCKED:_Thread waiting on a lock (synchronized)
  • WAITING: Thread waiting for a notification
  • TIME_WAITING: Waiting for timeout
  • TERMINATED:Thread finished execution

Understanding these states helps in managing concurrent applications effectively.

2. Thread State Transitions

1. Initial State (NEW)

Upon creating a thread, it enters the NEW state. To switch to runnable, call start(). This transition is immediate upon start() invocation.

2. Runnable State

  • Thread enters RUNNABLE state after visible thread selection by scheduler

3. Blocked State

  • Thread acquires a lock via synchronized keyword
  • Blocked until lock release by another thread

4. Waiting State

  • Thread calls wait() and releases lock
  • Blocks until notify() is called
  • No CPU time allocated

5. Time-Waiting State

  • Thread calls wait(time) with timeout specified
  • Release lock and waits until timeout or notify
  • No CPU time allocated

6. Terminated State

  • Normal completion of run()-Abnormal exit due to uncaught exceptions
  • main thread exit

3. State Transitions and Execution

Ordered States: NEW → RUNNABLE → ... → TERMINATED

  • States before RUNNABLE are immutable; cannot skip
  • States after RUNNABLE can backtrack

Avoid direct state transitions where not possible; follow APIs for state changes.

4. Thread State Examples

Example usage of wait() and notify():

public class WaitingExample implements Runnable {public static void main(String[] args) {WaitingExample Reversible = new WaitingExample();Thread t1 = new Thread(Reverable);Thread t2 = new Thread(Reverable);t1.start();t2.start();try {Thread.sleep(3);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("t1:" + t1.getState());System.out.println("t2:" + t2.getState());try {Thread.sleep(1400);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("t1:" + t1.getState());System.out.println("t2:" + t2.getState());}@Overridepublic void run() {method();}private synchronized void method() {try {Thread.sleep(1000);wait();} catch (InterruptedException e) {e.printStackTrace();}}}

5. Tips for Writing Lightweight Code

  • Avoid unnecessary locks
  • Optimize sleep durations
  • Consider thread pooling for better resource utilization
  • Minimize long waits

6. Summary

Understanding thread states helps manage concurrent applications effectively. Use Thread API methods to control state transitions and design thread-safe code carefully. Avoid over-engineering; keep code simple and efficient.

转载地址:http://bafqz.baihongyu.com/

你可能感兴趣的文章
Oracle 如何处理CLOB字段
查看>>
oracle 学习
查看>>
oracle 定义双重循环例子
查看>>
ORACLE 客户端工具连接oracle 12504
查看>>
Oracle 客户端连接时报ORA-01019错误总结
查看>>
oracle 导出sql数据库表结构,使用sql developer 导出Oracle数据库中的表结构
查看>>
oracle 嵌套表 例子,Oracle之嵌套表(了解)
查看>>
Oracle 常用命令
查看>>
Oracle 常用的V$视图脚本(二)
查看>>
Oracle 并行原理与示例总结
查看>>
oracle 并集 时间_Oracle集合运算符 交集 并集 差集
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
ORACLE 异常错误处理
查看>>
oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
查看>>
oracle 批量生成建同义词语句和付权语句
查看>>
oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
查看>>
Oracle 拆分以逗号分隔的字符串为多行数据
查看>>
Oracle 排序中使用nulls first 或者nulls last 语法
查看>>
oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
查看>>
Oracle 操作笔记
查看>>