标签:style for priority bsp mil 新建 super static 调度
java 中的线程优先级的范围是1~10,默认的优先级是5。10极最高。
有时间片轮循机制。“高优先级线程”被分配CPU的概率高于“低优先级线程”。根据时间片轮循调度,所以能够并发执行。无论是是级别相同还是不同,线程调用都不会绝对按照优先级执行,每次执行结果都不一样,调度算法无规律可循,所以线程之间不能有先后依赖关系。
无时间片轮循机制时,高级别的线程优先执行,如果低级别的线程正在运行时,有高级别线程可运行状态,则会执行完低级别线程,再去执行高级别线程。如果低级别线程处于等待、睡眠、阻塞状态,或者调用yield()函数让当前运行线程回到可运行状态,以允许具有相同优先级或者高级别的其他线程获得运行机会。因此,使用yield()的目的是让相同优先级的线程之间能适当的轮转执行。但是,实际中无法保证yield()达到让步目的,因为让步的线程还有可能被线程调度程序再次选中。结论:yield()从未导致线程转到等待/睡眠/阻塞状态。在大多数情况下,yield()将导致线程从运行状态转到可运行状态,但有可能没有效果。
优先级测试程序:
package com.first;
public class ThreadPriority
{
public static void main(String[] args) {
System.out.println(Thread.currentThread().getName()
+"("+Thread.currentThread().getPriority()+ ")");
Thread t1=new ThreadP("thread1"); //
新建t1
Thread t2=new ThreadP("thread2"); //
新建t2
t1.setPriority(5); // 设置t1的优先级为1
t2.setPriority(5); // 设置t2的优先级为10
t1.start(); // 启动t1
t2.start(); // 启动t2
}
}
class ThreadP extends
Thread{
public ThreadP(String name) {
super(name);
}
public void run(){
for (int i=0; i<5; i++) {
System.out.println(Thread.currentThread().getName()
+"("+Thread.currentThread().getPriority()+ ")"
+", loop "+i);
}
}
}
运行结果如下:
main(5)
thread2(10), loop 0
thread1(1), loop 0
thread2(10), loop 1
thread2(10), loop 2
thread2(10), loop 3
thread2(10), loop 4
thread1(1), loop 1
thread1(1), loop 2
thread1(1), loop 3
thread1(1), loop 4
标签:style for priority bsp mil 新建 super static 调度
原文地址:https://www.cnblogs.com/bclshuai/p/10245165.html