本文已参与「新人创作礼」活动,一起开启掘金创作之路。
一、程序的调度_分时调度模型和抢占式调度模型
在计算机中,线程调度有两种模型,分别是分时调度模型和抢占式调度模型。
分时调度模型是指让所有的线程轮流获得CPU的使用权,并且平均分配每个线程占用的CPU时间片。
抢占式调度模型是指让可运行池中优先级高的线程优先占用CPU,而对于优先级相同的线程,随机选择一个线程使其占用CPU,当它失去了CPU的使用权后,再随机选择其他线程获取CPU试用权。
Java虚拟机默认使用抢占式调度模型,大多数情况下程序员 不需要去关心它,但在某些特定的需求下需要改变这种模式,由程序自己来控制CPU的调度。
二、线程的优先级
在应用程序中,如果要对线程进行调度,最直接的方式就是设置线程的优先级。
优先级越高的线程获得 CPU 执行的机会越大,而优先级越低的线程获得 CPU 执行的机会越小。
程的优先级用1~10之间的整数来表示,数字越大优先级越高。
除了可以直接使用数字表示线程的优先级,还可以使用 Thread 类中提供的三个静态常量表示线程的优先级。
static int MAX_PRIORITY 表示线程的最高优先级,相当于值10
static int MIN_PRIORITY 表示线程的最低优先级,相当于值1
static int NORM_PRIORITY 表示线程的普通优先级,相当于值5
程序在运行期间,处于就绪状态的每个线程都有自己的优先级,例如 main 线程具有普通优先级。
然而线程优先级不是固定不变的,可以通过 Thread 类的 setPriority ( int newPriority )方法对其进行设置,该方法中的参数 newPriority 接收的是 1 ~10之间的整数或者 Thread 类的三个静态常量。
案例:
//线程的优先级
//定义类 MaxPriority 实现 Runnable 接口
class MaxPriority implements Runnable {
public void run() {
for (int i = 0;i<10;i++) {
System.out.println(Thread.currentThread().getName()+"正在输出:"+i);
//输出获取的当前的现成的名字
}
}
}
//定义类 MinPriority 实现 Runnable 接口
class MinPriority implements Runnable {
public void run() {
for (int i = 0;i<10;i++) {
System.out.println(Thread.currentThread().getName()+"正在输出:"+i);
//输出获取的当前的现成的名字
}
}
}
public class ExampleM07 {
public static void main(String[] args) {
//创建两个线程
Thread minPriority = new Thread(new MinPriority(),"优先级较低的程序");
Thread maxPriority = new Thread(new MaxPriority(),"优先级较高的程序");
minPriority.setPriority(Thread.MIN_PRIORITY);//设置线程的优先级为1
maxPriority.setPriority(10);//设置线程的优先级为10
//开启两个线程
maxPriority.start();
minPriority.start();
}
}