大家好,我是walker
一个从文科自学转行的程序员~
爱好编程,偶尔写写编程文章和生活
欢迎关注公众号【I am Walker】,回复“电子书”,就可以获得200多本编程相关电子书哈~
我的gitee:https://gitee.com/shen-chuhao/walker.git 里面很多技术案例!
Thread.yield()作用
暂停当前正在执行的线程对象(及放弃当前拥有的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()之后恢复到就绪状态,但并不意味着会进入阻塞状态,而是继续参与争夺时间片的过程中