线程的几个状态(转)

本文详细解析了Java中线程的生命周期,包括初始状态、可运行状态、运行状态及各种阻塞状态,并介绍了如何通过调用特定方法使线程在不同状态间转换。
[img]/upload/attachment/123361/8aef084f-4afd-3ab0-82aa-9fe1e4e613c4.jpg[/img]


小小的作下解释:
1、线程的实现有两种方式,一是继承Thread类,二是实现Runnable接口,但不管怎样,当我们new了这个对象后,线程就进入了初始状态;
2、当该对象调用了start()方法,就进入可运行状态;
3、进入可运行状态后,当该对象被操作系统选中,获得CPU时间片就会进入运行状态;
4、进入运行状态后情况就比较复杂了
4.1、run()方法或main()方法结束后,线程就进入终止状态;
4.2、当线程调用了自身的sleep()方法或其他线程的join()方法,就会进入阻塞状态(该状态既停止当前线程,但并不释放所占有的资源)。当sleep()结束或join()结束后,该线程进入可运行状态,继续等待OS分配时间片;
4.3、线程调用了yield()方法,意思是放弃当前获得的CPU时间片,回到可运行状态,这时与其他进程处于同等竞争状态,OS有可能会接着又让这个进程进入运行状态;
4.4、当线程刚进入可运行状态(注意,还没运行),发现将要调用的资源被synchroniza(同步),获取不到锁标记,将会立即进入锁池状态,等待获取锁标记(这时的锁池里也许已经有了其他线程在等待获取锁标记,这时它们处于队列状态,既先到先得),一旦线程获得锁标记后,就转入可运行状态,等待OS分配CPU时间片;
4.5、当线程调用wait()方法后会进入等待队列(进入这个状态会释放所占有的所有资源,与阻塞状态不同),进入这个状态后,是不能自动唤醒的,必须依靠其他线程调用notify()或notifyAll()方法才能被唤醒(由于notify()只是唤醒一个线程,但我们由不能确定具体唤醒的是哪一个线程,也许我们需要唤醒的线程不能够被唤醒,因此在实际使用时,一般都用notifyAll()方法,唤醒有所线程),线程被唤醒后会进入锁池,等待获取锁标记。
转自:http://www.blogjava.net/liver/archive/2009/06/04/279924.html
<think>好的,我现在需要回答用户关于Java线程状态的方法、获取和转换的问题。首先,我需要整理一下已有的引用内容,确保信息准确。 根据引用[1],Java线程状态的理解需要结合操作系统的线程状态,但具体的Java状态可能有不同。引用[2]提到线程状态转换图容易让人混淆,所以需要明确Java自身的状态分类。引用[3]和[4]指出存在五类或六类状态的情况,但用户提供的引用中引用[3]提到6种状态,引用[4]则倾向于五类。不过,官方Java文档中定义了六种状态,所以可能这里需要确认。但根据引用[3],Java线程有6种状态,包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED。而引用[5]补充了状态转换的具体方法,如join()导致的状态变化。 接下来,用户想知道用于操作或检查线程状态的方法。首先,获取线程状态的方法是Thread类的getState(),返回Thread.State枚举类型,包含上述六种状态。设置线程状态的方法其实并不是直接设置,而是通过调用不同的方法导致状态转换。例如,start()方法将线程从NEW为RUNNABLE,而wait()或join()会导致WAITING或TIMED_WAITING。 需要确保提到的每个方法对应的状态转换正确,如调用sleep()进入TIMED_WAITING,synchronized锁导致BLOCKED等。同时,要指出直接调用已终止线程的start()会抛出异常,如引用[3]所述。此外,引用[5]提到调用t.join(n)会让当前线程进入TIMED_WAITING状态,这点需要强调。 可能需要注意区分操作系统线程状态和Java线程状态的不同,如引用[1]和[2]提到的,但用户问题集中在Java层面,所以应专注于Thread.State中的定义。最后,总结关键方法,如getState()、start()、sleep()、wait()、notify()、join()等,并关联它们如何影响状态转换。 需要检查是否有遗漏的方法或状态转换,比如yield()方法是否影响状态,但根据Java文档,yield()不会改变状态,只是让出CPU时间,线程仍处于RUNNABLE状态。因此,不需要在转换中提到yield()。 确保回答结构清晰,分点列出获取方法、操作方法及其对应的状态转换,并引用正确的引用来源。可能还需要生成相关问题,如线程状态转换图、常见异常或不同方法的区别等。</think>### Java线程状态操作方法及转换机制 #### 一、获取线程状态的方法 1. **`Thread.getState()`** 该方法返回线程的当前状态,属于`Thread.State`枚举类型,包含6种状态: - `NEW`:线程被创建但未启动 - `RUNNABLE`:正在运行或等待CPU资源 - `BLOCKED`:等待监视器锁(如进入`synchronized`代码块) - `WAITING`:无限期等待(如调用`Object.wait()`或`Thread.join()`) - `TIMED_WAITING`:有限期等待(如调用`Thread.sleep(n)`或`Thread.join(n)`) - `TERMINATED`:线程已终止[^3][^4]。 #### 二、操作线程状态的方法及转换 1. **启动线程:`start()`** - 将线程从`NEW`转换为`RUNNABLE` - 若对已终止的线程调用`start()`,会抛出`IllegalThreadStateException`。 2. **主动让出CPU:`yield()`** - 线程仍保持`RUNNABLE`状态,仅提示调度器让出资源。 3. **休眠:`sleep(long millis)`** - 使线程进入`TIMED_WAITING`状态,休眠结束后回到`RUNNABLE`[^5]。 4. **等待锁或通知** - `synchronized`竞争锁失败时,线程进入`BLOCKED`状态。 - `Object.wait()`:线程释放锁并进入`WAITING`,需通过`notify()`/`notifyAll()`唤醒。 - `Object.wait(timeout)`:进入`TIMED_WAITING`状态。 5. **线程合并:`join()`** - `t.join()`:当前线程进入`WAITING`,直到线程`t`终止。 - `t.join(n)`:当前线程进入`TIMED_WAITING`,最多等待`n`毫。 6. **中断:`interrupt()`** - 向处于`WAITING`/`TIMED_WAITING`的线程发送中断信号,线程会抛出`InterruptedException`并回到`RUNNABLE`。 #### 三、状态转换示意图 ``` start() sleep()/join(n)/wait(n) wait()/join() NEW ──────────▶ RUNNABLE ──────────────────────────▶ TIMED_WAITING │ ▲ ▲ │ ▲ │ │ │ 唤醒/超时 │ │ 获取锁失败 │ │ 获取锁成功│ notify() │ │ ▼ │ │ ▼ │ BLOCKED ◀─────────┘ WAITING ▲ │ └──┘ 终止 TERMINATED ``` #### 四、注意事项 - 直接操作线程状态(如强制修改)可能导致不可预测行为,应通过标准API实现状态转换。 - `BLOCKED`状态仅与`synchronized`锁竞争相关,其他锁机制(如`ReentrantLock`)可能表现为`WAITING`[^1][^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值