java中yield 和join的作用

1.yeild作用:当前线程从运行状态变为可执行状态放弃当前cpu的资源,将它让给其他任务,包括自己,去占用cpu的执行时间,放弃的时间不确定,有可能刚刚放弃,马上又获得cpu的时间片。

只能使同优先级或者高优先级的线程得到执行机会。

cpu会从众多的可执行态里选择,也就是说,当前也就是刚刚的那个线程还是有可能会被再次执行到的,并不是说一定会执行其他线程而该线程在下一次中不会执行到了。

2.join:当前线程等待调用join()方法的线程执行完成后,再执行。

public class TestJoin {
    public static void main(String[] args) {
        Thread t1 = new Thread(new JoinDemo());
        t1.start();

        for (int i = 0; i < 20; i++) {
            System.out.println("主线程第" + i + "次执行!");
            if (i >= 5)
                try {
                    // t1线程合并到主线程中,主线程停止执行过程,转而执行t1线程,直到t1执行完毕后继续。
                    t1.join();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
        }
    }
}
public class JoinDemo implements  Runnable{
    @Override
    public void run() {
        for (int i = 0; i < 10; i++) {
            System.out.println("线程1第" + i + "次执行!");
        }
    }

}

结果:

java中yield 和join的作用_第1张图片

你可能感兴趣的:(java,高并发多线程)