Thread.yield()方法作用是:暂停当前正在执行的线程对象,并执行其他线程。 yield()应该做的是让当前运行线程回到可运行状态,以允许具有相同优先级的其他线程获得运行机会。因此,使用yield()的目的是让相同优先级的线程之间能适当的轮转执行。但是,实际中无法保证yield()达到让步目的,因为让步的线程还有可能被线程调度程序再次选中。 结论:yield()从未导致线程转到等待/睡眠/阻塞状态。在大多数情况下,yield()将导致线程从运行状态转到可运行状态,但有可能没有效果。public class TestYield { public static void main(String[] args) { MyThread3 t1 = new MyThread3("t1"); MyThread3 t2 = new MyThread3("t2"); t1.start(); t2.start(); } } class MyThread3 extends Thread { MyThread3(String s) { super(s); } public void run() { for(int i = 1;i <=100; i++) { System.out.println(getName() + ":"+i); if(i == 0) yield(); } } }class Demo implements Runnable{ public void run() { for(int x=0; x<50; x++) { System.out.println(Thread.currentThread().toString()+"....."+x); Thread.yield(); //释放资源 } }}class JoinDemo{ public static void main(String[] args) throws Exception { Demo d = new Demo(); Thread t1 = new Thread(d); Thread t2 = new Thread(d); t1.start(); t2.start();// t2.setPriority(Thread.MAX_PRIORITY);// t1.join();//t1 线程要申请加入进来,运行。临时加入一个线程运算时可以使用join方法。 //等待该线程终止。 for(int x=0; x<50; x++) {// System.out.println(Thread.currentThread()+"....."+x); } }}