java多线程之yield-阿里云开发者社区

开发者社区> 开发与运维> 正文

java多线程之yield

简介: java的Thread.yield,是暂停正在执行的线程,然后执行其他线程(包括被暂停的线程),但是无法保证执行yield方法的线程真正达到“让步”的目的,因为“让步”的线程也有可能被线程调度程序选中继续执行。

java的Thread.yield,是暂停正在执行的线程,然后执行其他线程(包括被暂停的线程),但是无法保证执行yield方法的线程真正达到“让步”的目的,因为“让步”的线程也有可能被线程调度程序选中继续执行。

class MyThread extends Thread {
	
	private String threadName;
	
	public MyThread(String threadName) {
		this.threadName = threadName;
	}
	
	@Override
	public void run() {
		for(int i = 0; i < 3; i++) {
			System.out.println(threadName + "输出" + i + ",并让出控制权。");
			Thread.yield();
		}
	}
	
}

public class ThreadYieldDemo {
	
	public static void main(String[] args) {
		MyThread t1 = new MyThread("t1");
		MyThread t2 = new MyThread("t2");
		t1.start();
		t2.start();
	}

}
第一次执行,结果如下:
t2输出0,并让出控制权。
t1输出0,并让出控制权。
t1输出1,并让出控制权。
t2输出1,并让出控制权。
t2输出2,并让出控制权。
t1输出2,并让出控制权。

第二次执行,结果如下:
t1输出0,并让出控制权。
t2输出0,并让出控制权。
t1输出1,并让出控制权。
t2输出1,并让出控制权。
t1输出2,并让出控制权。
t2输出2,并让出控制权。

可见结果是变化的,有的时候线程执行yield后又再次被cpu选中继续执行。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章