Java多线程编程:状态、协调与优化
1. 线程状态
在多线程系统中,系统调度器负责决定何时运行哪些线程。在Java里,调度器是基于优先级的抢占式调度器,它会优先选择执行优先级最高且准备好运行的线程。每个线程都有一个优先级,默认值为5,范围是0到10,线程会从其父线程继承优先级。虽然高优先级线程会更频繁地被调度,但在大多数应用中,所有线程使用默认优先级就足够了。
调度器会根据线程的行为,使其在四种不同的状态间循环:
- 创建(Created) :线程对象已创建,但尚未调用 start() 方法。调用 start() 后,线程进入可运行状态。
- 可运行(Runnable) :线程能够运行。调度器以先进先出(FIFO)的方式选择要执行的线程,每个核心在任何时候只能分配一个线程。线程会一直执行,直到阻塞(例如在同步语句中)、执行 yield() 、 suspend() 或 sleep() 语句、 run() 方法终止,或者被调度器抢占。当高优先级线程变为可运行状态,或者特定的时间片到期时,就会发生抢占。基于时间片的抢占确保所有线程最终都有机会执行,避免某些线程独占CPU。
- 阻塞(Blocked) :线程在等待锁、通知事件(如睡眠定时器到期、 resume() 方法执行),或者等待网络或磁盘请求完成时会进入阻塞状态。当阻塞线程等待的特定事件发生时,它会回
Java多线程编程:深入理解与实践
超级会员免费看
订阅专栏 解锁全文
10万+

被折叠的 条评论
为什么被折叠?



