Java多线程yield心得分享
一. thread.yield( )方法:
使当前线程从执行状态(运行状态)变为可执行态(就绪状态)。cpu会从众多的可执行态里选择,也就是说,当前也就是刚刚的那个线程还是有可能会被再次执行到的,并不是说一定会执行其他线程而该线程在下一次中不会执行到了。
java线程中有一个thread.yield( )方法,很多人翻译成线程让步。顾名思义,就是说当一个线程使用了这个方法之后,它就会把自己cpu执行的时间让掉,让自己或者其它的线程运行。
打个比方:现在有很多人在排队上厕所,好不容易轮到这个人上厕所了,突然这个人说:“我要和大家来个竞赛,看谁先抢到厕所!”,然后所有的人在同一起跑线冲向厕所,有可能是别人抢到了,也有可能他自己有抢到了。我们还知道线程有个优先级的问题,那么手里有优先权的这些人就一定能抢到厕所的位置吗? 不一定的,他们只是概率上大些,也有可能没特权的抢到了。
例子:
package com.yield;
public class yieldtest extends thread {
public yieldtest(string name) {
super(name);
}
@override
public void run() {
for (int i = 1; i <= 50; i++) {
system.out.println("" + this.getname() + "-----" + i);
// 当i为30时,该线程就会把cpu时间让掉,让其他或者自己的线程执行(也就是谁先抢到谁执行)
if (i == 30) {
this.yield();
}
}
}
public static void main(string[] args) {
yieldtest yt1 = new yieldtest("张三");
yieldtest yt2 = new yieldtest("李四");
yt1.start();
yt2.start();
}
}
运行结果:
第一种情况:李四(线程)当执行到30时会cpu时间让掉,这时张三(线程)抢到cpu时间并执行。
第二种情况:李四(线程)当执行到30时会cpu时间让掉,这时李四(线程)抢到cpu时间并执行。