sleep与yield异同

sleep:是Thread类的一个静态方法,该方法会让当前正在 执行的线程暂停执行,从而将执行机会让给其他线程执行。sleep(long mills)参数指定当前线程暂停执行的时间,经过这段阻塞时间后,该线程会进入就绪状态,等候线程调度器的调度。sleep方法声明抛出了InterruptedException异常,所以调用sleep方法时要么在方法开始处抛出异常要么使用try{}..catch{}块进行捕获。

yield方法只会给优先级相同或更高优先级的线程执行机会。yield不会将线程转入阻塞状态,只是强制当前线程进入就绪状态。因此完全有可能某个线程调用yield方法暂停后,立即又获得处理器资源被执行。yield方法没有声明抛出任何异常。

sleep比yield方法有更好的可移植性,通常,不要依靠yield控制并发线程的执行。

code:

sleep

public class SleepDemo extends Thread 
{
public SleepDemo(String name)
{
super(name);
}


public void run()
{
for(int i=0;i<50;i++)
{
  System.out.println(getName()+"----"+i);
  if(i==20)
  {
try
{
Thread.sleep(1000*10);
}
catch (Exception e)
{
e.printStackTrace();
}
  }
}

}
public static void main(String[] args) 
{
SleepDemo t = new SleepDemo("新线程");
t.start();


for(int i=0;i<30;i++)
{


System.out.println(Thread.currentThread().getName()+"---"+i);
if(i == 15)
   try
   {
Thread.sleep(1000*10);
   }
   catch (Exception e)
   {
e.printStackTrace();
   }
 
}
}
}



yield

public class YieldThread extends Thread 
{
public YieldThread(String name)
{
super(name);
}


public YieldThread()
{


}


public void run()
{
for(int i=0;i<50;i++){
System.out.println(getName()+"--->"+i);
if(i == 20)
{
Thread.yield();
}
}
}


public static void main(String[] args) 
{
YieldThread t1 = new YieldThread("高级");
t1.start();
// 若当前线程优先级最高,那么即使调用了yield()方法,线程调度器又会将这个线程调度出来重新执行
//t1.setPriority(Thread.MAX_PRIPORITY);
YieldThread t2 = new YieldThread("低级");
t2.start();
t2.setPriority(Thread.MIN_PRIORITY);
//System.out.println("Hello World!");
}
}

你可能感兴趣的:(线程,sleep,yield)