Java并发编程示例(五):线程休眠与恢复

 更新时间:2014年12月05日 10:18:43   投稿:junjie  
这篇文章主要介绍了Java并发编程示例(五):线程休眠与恢复,在本节,我们将开发一个程序,使用sleep()方法来实现每秒钟打印一次当前时间,需要的朋友可以参考下

有时,我们需要在指定的时间点中断正在执行的线程。比如,每分钟检查一次传感器状态的线程,其余时间,线程不需要做任何事情。在此期间,线程不需要使用计算机的任何资源。过了这段时间之后,并且当Java虚拟机调度了该线程,则该线程继续执行。为此,你可以使用Thread类的sleeep()方法。该方法以休眠的方式来推迟线程的执行,而且整数类型的参数则指明休眠的毫秒数。当调用sleep()方法,休眠时间结束后,Java虚拟机分配给线程CPU运行时间,线程就会继续执行。

另一种是用sleep()方法的方式是通过枚举类型TimeUnit的元素。该方式使用Thread的sleep()方法来使得当前线程进行休眠,它可以接受指定单位的时间作为参数,并将这些其转换成对应的毫秒数。

在本节,我们将开发一个程序,使用sleep()方法来实现每秒钟打印一次当前时间。

知其然

按照下面所示步骤,来实现本节示例。

1.创建一个名为FileClock的类,并且实现Runnable接口。代码如下:

复制代码 代码如下:

public class FileClock implements Runnable {

2.实现run()方法。代码如下:
复制代码 代码如下:

@Override
public void run() {

3.写一个遍历十次的循环,在每次迭代中,创建一个Date对象,并将其打印到控制台。然后,通过TimeUtil的SECONDS属性调用sleep()方法,来延迟一秒钟执行线程。以为sleep()方法会抛出InterruptedException异常。所以,我们需要多写几行代码,用来捕获异常。当线程可能中断是,释放或者关闭在线程中使用的资源,总是最佳实践。代码如下:
复制代码 代码如下:

for (int i = 0; i < 10; i++) {
    System.out.printf("%s\n", new Date());
    try {
        TimeUnit.SECONDS.sleep(1);
    } catch (InterruptedException e) {
        System.out.printf("The FileClock has been interrupted.\n");
    }
}

4.我们已经有了实现好的线程类。现在,我们来实现主类。创建一个名为FileMain的类,并且实现main()方法。代码如下:

复制代码 代码如下:

public class FileMain {
    public static void main(String[] args) {

5.创建一个FileClock对象,再创建一个线程用于执行任务。然后,启动线程。代码如下:

复制代码 代码如下:

FileClock clock = new FileClock();
Thread thread = new Thread(clock);
thread.start();

6.在主线程中,通过TimeUtil的SECONDS属性调用sleep()方法,来等待五秒钟。代码如下:
复制代码 代码如下:

try {
    TimeUnit.SECONDS.sleep(5);
} catch (InterruptedException e) {
    e.printStackTrace();
}

7.中断FileClock线程。代码如下:

复制代码 代码如下:

thread.interrupt();

8.执行示例,查看执行效果。

知其所以然

当执行这个程序时,会发现,程序如何每秒钟打印一次日期对象,以及线程被中断的情况。

当调用sleep()方法时,线程将离开CPU,并停止执行一段时间。在这段时间内,线程不需要CPU了,所以CPU可以执行其他任务。

当休眠中的线程被中断时,会立即抛出一个InterruptedException,而不是等到休眠结束。

永无止境

Java并发API中,还有另外一个方法可以让线程让出CPU。这就是yield()方法,调用该方法就是想Java虚拟机发送消息说明线程可以让出CPU给其他线程。Java虚拟机并不保证响应这个请求。一般情况下,该方法仅仅在调试程序时使用。

拿来主义

本文是从 《Java 7 Concurrency Cookbook》 (D瓜哥窃译为 《Java7并发示例集》 )翻译而来,仅作为学习资料使用。没有授权,不得用于任何商业行为。

小有所成

本节所用的示例代码的完整版。

FileClock类的完整代码

复制代码 代码如下:

package com.diguage.books.concurrencycookbook.chapter1.recipe5;

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

/**
 * 每秒向控制台打印出当前日期和时间。
 * Date: 2013-09-18
 * Time: 23:11
 */
public class FileClock implements Runnable {
    @Override
    public void run() {
        for (int i = 0; i < 10; i++) {
            System.out.printf("%s\n", new Date());
            try {
                TimeUnit.SECONDS.sleep(1);
            } catch (InterruptedException e) {
                System.out.printf("The FileClock has been interrupted.\n");
            }
        }
    }

FileMain类的完整代码

复制代码 代码如下:

package com.diguage.books.concurrencycookbook.chapter1.recipe5;

import java.util.concurrent.TimeUnit;

/**
 * 演示线程休眠和恢复
 * Date: 2013-09-19
 * Time: 00:29
 */
public class FileMain {
    public static void main(String[] args) {
        FileClock clock = new FileClock();
        Thread thread = new Thread(clock);
        thread.start();

        try {
            TimeUnit.SECONDS.sleep(5);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        thread.interrupt();
    }
}

相关文章

  • Netty + ZooKeeper 实现简单的服务注册与发现

    Netty + ZooKeeper 实现简单的服务注册与发现

    服务注册和发现一直是分布式的核心组件。本文介绍了借助 ZooKeeper 做注册中心,如何实现一个简单的服务注册和发现。,需要的朋友可以参考下
    2019-06-06
  • SpringBoot自定义HttpMessageConverter操作

    SpringBoot自定义HttpMessageConverter操作

    这篇文章主要介绍了SpringBoot自定义HttpMessageConverter的操作,具有很好的参考价值,如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • JUnit5中的参数化测试实现

    JUnit5中的参数化测试实现

    参数化测试使得我们可以使用不同的参数运行同一个测试方法,从而减少我们编写测试用例的工作量,本文主要介绍了JUnit5中的参数化测试实现,感兴趣的可以了解一下
    2023-05-05
  • java 反射 动态调用不同类的静态方法(推荐)

    java 反射 动态调用不同类的静态方法(推荐)

    下面小编就为大家带来一篇JAVA 反射 动态调用不同类的静态方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • Spring Boot通过Junit实现单元测试过程解析

    Spring Boot通过Junit实现单元测试过程解析

    这篇文章主要介绍了Spring Boot通过Junit实现单元测试过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • 如何通过XML方式配置并实现Mybatis

    如何通过XML方式配置并实现Mybatis

    这篇文章主要介绍了如何通过XML方式配置并实现Mybatis,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • java struts2学习笔记之线程安全

    java struts2学习笔记之线程安全

    这篇文章主要为大家详细介绍了java struts2学习笔记之线程安全,感兴趣的朋友可以参考一下
    2016-04-04
  • Java访问数据库实例详解

    Java访问数据库实例详解

    这篇文章主要为大家详细介绍了Java访问数据库实例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 详解Java递归实现树形结构的两种方式

    详解Java递归实现树形结构的两种方式

    在开发的过程中,很多业务场景需要一个树形结构的结果集进行前端展示,也可以理解为是一个无限父子结构,常见的有报表指标结构、菜单结构等,这篇文章主要介绍了Java递归实现树形结构的两种方式,需要的朋友可以参考下
    2022-10-10
  • idea远程debug调试部署在tomcat上项目

    idea远程debug调试部署在tomcat上项目

    本文主要介绍了idea远程debug调试部署在tomcat上项目,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08

最新评论