一.优先级
在多线程系统中,每一个线程都被赋予一个执行优先级,优先级决定了线程被CPU执行的优先顺序,优先级高的线程可以在一段时间里获得比优先级低的线程更多的执行时间。
Java语言中优先级被分成10级,分别从低到高用整数1~10表示。
Thread类里面有三个关于线程优先级的静态变量,
MIN_PRIORITY表示最小优先级,通常为1.
MAX_PRIORITY表示最大优先级,通常为10.
NORM_PRIORITY表示普通优先级,默认值为5.
对于一个新建的线程,系统会遵循如下的原则为线程指定优先级:
新建线程将继承创建它的父线程的优先级 |
一般情况下,主线程具有普通优先级。 |
如果想改变线程的优先级,可以调用线程对象的setPriority()方法进行设置。
二.调度
调度就是在各个线程之间分配CPU资源,多线程的并发执行实际上是通过一个调度来进行的。
调度一般有两个模型:
1.分时模型
在分时模型中,CPU的资源是按照时间片分配的,获得CPU资源的线程只能在指定的时间片内执行,当时间片使用完,就必须给另外一个处于就绪状态的线程。在分时状态中,线程本身不会让出CPU。
2.抢占模型
在抢占模型中,当前活动的线程一旦获得执行权,它就会一直执行下去,直到执行完毕或由于某些原因主动放弃执行权。如果当前有一个低优先级的线程正在执行,此时一个高优先级的线程准备就绪,那么低优先级的线程会把CPU的资源让给高优先级的线程。为了能使低优先级的线程能有执行的机会,高优先级的线程应该不定时的主动进入“睡眠”状态,暂时让出CPU。