JavaSE-20.1.3【线程优先级】
1 package day11.lesson1.p3; 2 3 /* 4 1.4 线程优先级 5 6 1、线程调度 7 (1)两种调度方式 8 分时调度模型:所有线程轮流使用 CPU 的使用权,平均分配每个线程占用 CPU 的时间片 9 抢占式调度模型:优先让优先级高的线程使用 CPU,如果线程的优先级相同,那么会随机选择一个,优先级高的线程获取的 CPU 时间片相对多一些 10 (2)Java使用的是抢占式调度模型 11 (3)随机性 12 假如计算机只有一个 CPU,那么 CPU 在某一个时刻只能执行一条指令,线程只有得到CPU时间片, 13 也就是使用权,才可以执行指令。所以说多线程程序的执行是有随机性,因为谁抢到CPU的使用权是不一定的 14 15 2、优先级相关方法 16 final int getPriority() 返回此线程的优先级 17 final void setPriority(int newPriority) 更改此线程的优先级 18 线程默认优先级是5;线程优先级的范围是:1-10 19 */ 20 public class ThreadPriorityDemo { 21 public static void main(String[] args) { 22 ThreadPriority tp1 = new ThreadPriority(); 23 ThreadPriority tp2 = new ThreadPriority(); 24 ThreadPriority tp3 = new ThreadPriority(); 25 26 tp1.setName("高铁"); 27 tp2.setName("飞机"); 28 tp3.setName("汽车"); 29 30 /*System.out.println(tp1.getPriority()); //5 31 System.out.println(tp2.getPriority()); //5 32 System.out.println(tp3.getPriority()); //5*/ 33 34 tp1.setPriority(Thread.MAX_PRIORITY); //10 35 tp2.setPriority(Thread.MIN_PRIORITY); //1 36 tp3.setPriority(Thread.NORM_PRIORITY); //5 37 38 System.out.println(tp1.getPriority()); //10 39 System.out.println(tp2.getPriority()); //1 40 System.out.println(tp3.getPriority()); //5 41 42 tp1.start(); 43 tp2.start(); 44 tp3.start(); 45 } 46 }
1 package day11.lesson1.p3; 2 3 public class ThreadPriority extends Thread{ 4 5 @Override 6 public void run() { 7 for (int i=0; i<100; i++){ 8 System.out.println(getName() + ":" + i); 9 } 10 } 11 12 }