Thread.yield()方法作用是:暂停当前正在执行的线程对象,并执行其他线程。
yield()应该做的是让当前运行线程回到可运行状态,以允许具有相同优先级的其他线程获得运行机会。因此,使用yield()的目的是让相同优先级的线程之间能适当的轮转执行。但是,实际中无法保证yield()达到让步目的,因为让步的线程还有可能被线程调度程序再次选中。
结论:yield()从未导致线程转到等待/睡眠/阻塞状态。在大多数情况下,yield()将导致线程从运行状态转到可运行状态,但有可能没有效果。
暂停当前正在执行的线程对象,并执行其他线程。
yield()应该做的是让当前运行线程回到可运行状态,以允许具有相同优先级的其他线程获得运行机会。因此,使用yield()的目的是让相同优先级的线程之间能适当的轮转执行。但是,实际中无法保证yield()达到让步目的,因为让步的线程还有可能被线程调度程序再次选中。
结论:yield()从未导致线程转到等待/睡眠/阻塞状态。在大多数情况下,yield()将导致线程从运行状态转到可运行状态,但有可能没有效果。
package com.designpattern.concurrent.thread;
/** * Created by zhu wei on 2017/6/2 0002. */ public class YiledTest implements Runnable { private String name; public YiledTest(String name) { this.name = name; } public void run() { for (int i = 0; i < 100; i++) { System.out.println(name + ":" + i); if ("t1".equals(name) && i == 5) { System.out.println(name + ":" + i +"......yield............."); Thread.yield(); } } } /** * 暂停当前正在执行的线程对象,并执行其他线程。 * * @param args * @throws Exception */ public static void main(String[] args) throws Exception { Thread t1 = new Thread(new YiledTest("t1")); Thread t2 = new Thread(new YiledTest("t2")); t1.start(); t2.start(); }
版权声明:本文为zhuwei898321原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。