您的位置:首页 > 其它

线程中sleep()方法和yield()方法

2016-03-29 16:33 197 查看
一. Thread.yield( )方法:

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

Java线程中有一个Thread.yield( )方法,很多人翻译成线程让步。顾名思义,就是说当一个线程使用了这个方法之后,它就会把自己CPU执行的时间让掉,让自己或者其它的线程运行。

打个比方:现在有很多人在排队上厕所,好不容易轮到这个人上厕所了,突然这个人说:“我要和大家来个竞赛,看谁先抢到厕所!”,然后所有的人在同一起跑线冲向厕所,有可能是别人抢到了,也有可能他自己有抢到了。我们还知道线程有个优先级的问题,那么手里有优先权的这些人就一定能抢到厕所的位置吗? 不一定的,他们只是概率上大些,也有可能没特权的抢到了。

例子:

?
运行结果:

第一种情况:李四(线程)当执行到30时会CPU时间让掉,这时张三(线程)抢到CPU时间并执行。



第二种情况:李四(线程)当执行到30时会CPU时间让掉,这时李四(线程)抢到CPU时间并执行。

Thread.sleep(long millis)和Thread.sleep(long millis, int nanos)静态方法强制当前正在执行的线程休眠(暂停执行),以“减慢线程”。

当线程睡眠时,它睡在某个地方,在苏醒之前不会返回到可运行状态。

当睡眠时间到期,则返回到可运行状态。

线程睡眠的原因:线程执行太快,或者需要强制进入下一轮,因为Java规范不保证合理的轮换。

睡眠的实现:调用静态方法。

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

e.printStackTrace();

}

睡眠的位置:为了让其他线程有机会执行,可以将Thread.sleep()的调用放线程run()之内。这样才能保证该线程执行过程中会睡眠。

public class TestSleep {

public static void main(String[] args) {

MyThread2 t1 = new MyThread2("TestSleep");

t1.start();

for(int i=0 ; i <10; i++)

System.out.println("I am Main Thread");

}

}

class MyThread2 extends Thread {

MyThread2(String s) {

super(s);

}

public void run() {

for(int i = 1; i <= 10; i++) {

System.out.println("I am "+getName());

try {

sleep(1000); //暂停,每一秒输出一次

}catch (InterruptedException e) {

return;

}

}

}

}

注意:

1、线程睡眠是帮助所有线程获得运行机会的最好方法。

2、线程睡眠到期自动苏醒,并返回到可运行状态,不是运行状态。sleep()中指定的时间是线程不会运行的最短时间。因此,sleep()方法不能保证该线程睡眠到期后就开始执行。

3、sleep()是静态方法,只能控制当前正在运行的线程。

实例二:一个计数器,计数到100,在每个数字之间暂停1秒,每隔10个数字输出一个字符串

public class MyThread extends Thread {

public void run() {

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

if ((i) % 10 == 0) {

System.out.println("-------" + i);

}

System.out.print(i);

try {

Thread.sleep(1000);

System.out.print(" 线程睡眠1秒!\n");

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

public static void main(String[] args) {

new MyThread().start();

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: