一 线程的调度
- 分时调度模型:所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU的时间片。
- 抢占式调度模型:优先级高的线程先得到CPU资源,如果线程的优先级相同,那么会随机选择一个,优先级高的线程获取CPU时间片相对多一些。(Java使用的为抢占式调度模型)
随机性:假如计算机只有一个CPU,那么CPU再某一时刻只能执行一条命令,线程只能在得到CPU的时间片,即CPU的使用权的时候,才能够执行指令。
在多线程程序的执行过程中是存在随机性,因为谁抢到CPU的使用权是存在随机性的。
本文探讨了两种主要的线程调度模型:分时调度和抢占式调度。分时调度确保所有线程公平地共享CPU资源,而抢占式调度则依据线程优先级分配执行时间。在Java中,采用的是抢占式模型,高优先级线程优先执行。线程执行的随机性源于CPU使用权的随机分配,这在多线程编程中造成了一定的不可预测性。
7198

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



