并发编程实战 1.4. 线程的休眠与恢复 - sleep()
并发编程实战 1.4. 线程的休眠与恢复 - sleep()
火犀牛 发表于2年前
并发编程实战 1.4. 线程的休眠与恢复 - sleep()
  • 发表于 2年前
  • 阅读 2
  • 收藏 0
  • 点赞 2
  • 评论 0

移动开发云端新模式探索实践 >>>   

摘要: 睡眠可以使用 Thread.sleep() 或者使用 TimeUtil.SECOND.sleep()
线程睡眠可以使用 Thread.sleep() 或者使用 TimeUtil.SECOND.sleep()方法

范例:循环打印日期, 5秒后打断

package com.rr.current2.c1_4_sleep.test;

import java.util.Date;
import java.util.concurrent.TimeUnit;

/**
 * Created by Isaac on 16-5-10.
 */
public class Task implements Runnable  {

    @Override
    public void run() {

        for(int i = 0 ; i++ < 10;){
            System.out.printf("当前的时间为: %s\r\n", new Date());
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                System.out.printf("%s 被打断!\r\n",Thread.currentThread().getName());
            }
        }
    }
}

测试:

package com.rr.current2.c1_4_sleep.test;

import java.util.concurrent.TimeUnit;

/**
 * Created by Isaac on 16-5-10.
 * 睡眠可以使用 Thread.sleep() 或者使用 TimeUtil.SECOND.sleep()
 * 范例: 循环打印日期, 5秒后打断
 */
public class Test {
    public static void main(String[] args) {
        Thread thread = new Thread(new Task());
        thread.start();
        System.out.println("main start!");
        try {
            TimeUnit.SECONDS.sleep(5);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        thread.interrupt();
        System.out.println("main end!");
    }
}

结果:

main start!
当前的时间为: Tue May 10 22:14:52 CST 2016
当前的时间为: Tue May 10 22:14:53 CST 2016
当前的时间为: Tue May 10 22:14:54 CST 2016
当前的时间为: Tue May 10 22:14:55 CST 2016
当前的时间为: Tue May 10 22:14:56 CST 2016
main end!
Thread-0 被打断!
当前的时间为: Tue May 10 22:14:57 CST 2016
当前的时间为: Tue May 10 22:14:58 CST 2016
当前的时间为: Tue May 10 22:14:59 CST 2016
当前的时间为: Tue May 10 22:15:00 CST 2016
当前的时间为: Tue May 10 22:15:01 CST 2016

补充yield:yield()只是使当前线程重新回到可执行状态,所以执行yield()的线程有可能在进入到可执行状态后马上又被执行。通常来讲,yield()方法方法只做调试使用。

  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 0
博文 27
码字总数 12180
×
火犀牛
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: