线程的优先级
线程调度
-
两种调度方式
-
分时调度模型:所有线程轮流使用 CPU 的使用权,平均分配每个线程占用 CPU 的时间片
-
抢占式调度模型:优先让优先级高的线程使用 CPU,如果线程的优先级相同,那么会随机选择一个,优先级高的线程获取的 CPU 时间片相对多一些
-
-
Java使用的是抢占式调度模型
-
随机性
假如计算机只有一个 CPU,那么 CPU 在某一个时刻只能执行一条指令,线程只有得到CPU时间片,也就是使用权,才可以执行指令。所以说多线程程序的执行是有随机性,因为谁抢到CPU的使用权是不一定的
方法名 | 说明 |
---|---|
final int getPriority() | 返回此线程的优先级 |
final void setPriority(int newPriority) | 更改此线程的优先级线程默认优先级是5;线程优先级的范围是:1-10 |
切记:优先级越高只是抢到cpu执行权的几率越高
代码演示:
/**
* 线程优先级是1~10 默认是5
*/
public class Demo {
public static void main(String[] args) {
CallableImpl callable = new CallableImpl();
FutureTask<String> ft = new FutureTask<String>(callable);
Thread t1 = new Thread(ft);
// System.out.println(t1.getPriority());
t1.setName("线程一");
t1.setPriority(10);
t1.start();
CallableImpl callable1 = new CallableImpl();
FutureTask<String> ft1 = new FutureTask<String>(callable1);
Thread t2 = new Thread(ft1);
t2.setName("线程二");
// System.out.println(t2.getPriority());
t2.start();
}
}
import java.util.concurrent.Callable;
public class CallableImpl implements Callable<String> {
@Override
public String call() throws Exception {
for (int i = 0; i < 100; i++) {
System.out.println(Thread.currentThread().getName()+"----"+i);
}
return "線程執行完畢";
}
}
守护线程
为了守护普通线程而存在
当普通线程执行完毕后守护线程也就消失了
方法名 | 说明 |
---|---|
void setDaemon(boolean on) | 将此线程标记为守护线程,当运行的线程都是守护线程时,Java虚拟机将退出 |