Java多线程编程:从基础到高级应用
1. 死锁问题
在数据库操作中,死锁是一个常见的问题。例如,一个用户请求在 Students 数据库表中的某些数据上获取锁,然后必须更新 Classes 表中的行以反映学生的出勤情况。与此同时,另一个用户请求在 Classes 表上获取锁,然后必须更新 Students 表中的一些信息。如果这些请求以重叠的方式获取锁,就会发生死锁。
2. 线程状态
多线程系统有一个系统调度器,它决定何时运行哪些线程。在Java中,调度器是一种基于优先级的抢占式调度器,它会选择执行优先级最高且希望运行的线程。
每个线程都有一个优先级(默认值为5,范围是0到10),线程会从其父线程继承优先级。高优先级线程比低优先级线程更频繁地被调度,但在大多数应用程序中,所有线程使用默认优先级就足够了。
调度器根据线程的行为将线程循环通过四种不同的状态:
- 创建(Created) :线程对象已创建,但尚未调用其 start() 方法。一旦调用 start() 方法,线程就进入可运行状态。
- 可运行(Runnable) :线程能够运行。调度器将以先进先出(FIFO)的方式选择要执行的线程,每个节点的每个核心在任何时候只能分配一个线程。线程会一直执行,直到它们阻塞(例如,在同步语句上)、执行 yield() 、 susp
超级会员免费看
订阅专栏 解锁全文
2127

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



