java中什么是Yield给出一个例子
马克-to-win:yield英文是屈服投降的意思。 当前线程投降就是当前线程希望释放CPU的自己的占用权,( 但系统可以忽略它这个请求。)参见: https://docs.oracle.com/javase/7/docs/api/java/lang/Thread.html#yield%28%29 其中有这么句话: A hint to the scheduler that the current thread is willing to yield its current use of a processor. The scheduler is free to ignore this hint.这样的话当前线程yield时,有时虽然它自己想让别的线程执行,但系统出于优化考虑,可能还是会让当前的线程继续执行。这样的话,yield 就会有一种不可控的效果,所以并行编程的最佳实践建议少用yield。马克- to-win:马克 java社区:防盗版实名手机尾号: 73203。
例:1.5.5-本章源码
class ThreadMark_to_win extends Thread {
private String s;
public ThreadMark_to_win(String s) {
this.s = s;
}
public void run() {
for (int i = 0; i < 10; i++) {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
}
System.out.println(s);
/*当前线程希望释放CPU的自己的占用权,( 但系统可以忽略。) */
Thread.yield();
}
}
}
public class Test {
public static void main(String[] args) {
Thread t1 = new ThreadMark_to_win("线程1");
Thread t2 = new ThreadMark_to_win("线程2");
t1.start();
t2.start();
}
}
运行结果:
线程1
线程2
线程2
线程1
线程1
线程2
线程2
线程1
线程2
线程1
线程1
线程2
线程2
线程1
线程1
线程2
线程2
线程1
线程2
线程1
后续:
马克-to-win:根据结果可以看出:结果并不是1,2之间稳定交替,而是不可控的状态。