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之间稳定交替,而是不可控的状态。