暂停当前正在执行的线程对象(及放弃当前拥有的cup资源),并执行其他线程。yield()做的是让当前运行线程回到可运行状态,以允许具有相同优先级的其他线程获得运行机会。
但是这并不意味着,下一次获取时间片的线程不是另一个线程,也有可能是使用yield的线程
是否使用yield的对比 没有使用yield的情况package ThreadMethod;
public class NotYieldTest {
public static void main(String[] args) {
new Thread(()->{
System.out.println(Thread.currentThread().getName()+"执行");
System.out.println(Thread.currentThread().getName()+"执行结束");
},"线程A").start();
for (int i = 0; i < 2; i++) {
new Thread(()->{
System.out.println(Thread.currentThread().getName()+"执行");
System.out.println(Thread.currentThread().getName()+"执行结束");
},"线程B"+i).start();
}
}
}
执行结果:
没有使用Thread.yield(),单核CPU条件下线程是会按照顺序进行执行
线程A执行 线程A执行结束 线程B0执行 线程B0执行结束 线程B1执行 线程B1执行结束使用yield的情况
package ThreadMethod;
public class YieldTest {
public static void main(String[] args) {
new Thread(()->{
System.out.println(Thread.currentThread().getName()+"执行");
Thread.yield();
System.out.println(Thread.currentThread().getName()+"执行结束");
},"线程A").start();
for (int i = 0; i < 2; i++) {
new Thread(()->{
System.out.println(Thread.currentThread().getName()+"执行");
System.out.println(Thread.currentThread().getName()+"执行结束");
},"线程B").start();
}
}
}
将代码进行多次执行,主要有以下两种情况:
执行结果1: 线程A执行 线程B执行 线程B执行结束 线程B执行 线程B执行结束 线程A执行结束 执行结果2: 线程A执行 线程A执行结束 线程B执行 线程B执行 线程B执行结束 线程B执行结束
一种结果是线程A执行之后到了线程B执行,一种是线程A全部执行完之后再到线程B
这里就说明了,线程A在使用Thread.yield()之后恢复到就绪状态,但并不意味着会进入阻塞状态,而是继续参与争夺时间片的过程中



