java中线程优先级是怎么回事给出一个例子
线程优先级
马克- to-win:马克 java社区:防盗版实名手机尾号: 73203。
java 中线程的优先级用1-10之间的数字表示,数值越大优先级越高,默认的优先级为5。Java中的线程优先级是在Thread类中定义的常量 NORM_PRIORITY : 值为5,MAX_PRIORITY :值为10,MIN_PRIORITY : 值为1,缺省优先级为 NORM_PRIORITY。有关优先级的常用方法有两个:1)final void setPriority(int newp) : 修改线程的当前优先级 2)final int getPriority() : 返回线程的优先级。马克-to-win:线程的优先级不能担保线程的执行次序。优先级高的线程获取CPU执行的几率较大,优先级低的线程也有机会执行。参考http://www.javamex.com/tutorials/threads/priority_what.shtml其中有句: there'd quite possibly be lower-priority threads that barely got any CPU at all, being continually starved by higher-priority threads that needed CPU. So Windows has a fallback mechanism, whereby a thread that hasn't run for a long time is given a temporary priority boost.大致意思:为防止低优先级的线程被饿死,Windows有个抗争的方法,给低优先级的线程一个优先级的临时提升。。。。。。更多的请大家参考此网站。
例:1.6.1-本章源码
class ThreadMark_to_win extends Thread {
static boolean go=true;
private String s;
int i;
public ThreadMark_to_win(String s) {
this.s = s;
}
public void run() {
while(go){
System.out.println(s+" 到了 "+i++);
try {
this.sleep(1);
} catch (InterruptedException ex) {
ex.printStackTrace();
}
}
}
}
public class Test {
public static void main(String[] args) {
Thread t1 = new ThreadMark_to_win("线程1");
Thread t2 = new ThreadMark_to_win("线程2");
t1.setPriority(1);
t2.setPriority(10);
t1.start();
t2.start();
try {
Thread.sleep(30000);
} catch (InterruptedException e) {
e.printStackTrace();
}
ThreadMark_to_win.go=false;
}
}
输出结果:
线程1 到了 0
线程2 到了 0
线程1 到了 1
线程2 到了 1
线程2 到了 2
线程1 到了 2
线程2 到了 3
线程1 到了 3
线程2 到了 4
线程1 到了 4
线程2 到了 5
线程1 到了 5
线程2 到了 6
线程1 到了 6
。
。
。
。
。
。
。
线程1 到了 3335
线程2 到了 4753
线程2 到了 4754
线程2 到了 4755
线程2 到了 4756
线程1 到了 3336
线程2 到了 4757
线程2 到了 4758
线程2 到了 4759
后续:马克-to-win:上述程序中,boolean go=true; 被设置成静态变量, 这样, 它就可以被多个类或者说线程共享了,主线程睡了30秒以后,一下同时停止了两个线程。可以看出2 比1,多跑了1000 多个数, 但开始时并不明显,路遥知马力!