sleep() 方法的作用是在指定的毫秒数内让当前“正在执行的线程”休眠(暂停执行)。这个“正在执行的线程”是指 this.currentThread() 返回的线程。

例 1

下面通过一个案例来理解使用 sleep() 方法判断线程是否活动的标准。假设 MyThread10 线程类的代码如下:

package ch14;
public class MyThread10 extends Thread
{
@Override
public void run()
{
try
{
System.out.println("正在运行的线程名称:"+this.currentThread().getName()+" 开始");
Thread.sleep(2000); //延时2秒
System.out.println("正在运行的线程名称:"+this.currentThread().getName()+" 结束");
}
catch(InterruptedException e)
{
e.printStackTrace();
}
}
}
下面编写启动 MyThread10 线程的代码,具体实现如下: package ch14;
public class Test14
{
public static void main(String[] args)
{
MyThread11 mythread=new MyThread11();
System.out.println("主线程开始时间="+System.currentTimeMillis());
mythread.start();
System.out.println("主线程结束时间="+System.currentTimeMillis());
}
}

  

如上述代码所示,主线程创建一个 MyThread10 线程实例之后直接调用 run() 方法启动线程,整个过程都在主线程中完成。程序运行后的输出结果如下所示。

主线程开始时间=1540963362783
主线程结束时间=1540963362783
正在运行的线程名称:Thread-0 开始
正在运行的线程名称:Thread-0 结束

例 2

上个案例子线程中的延时导致主线程也进行了延时。下面再看一个 sleep() 方法应用的案例,这里使用的是 MyThread11 线程类,该类代码如下:

package ch14;
public class MyThread11 extends Thread
{
@Override
public void run()
{
try
{
System.out.println("正在运行的线程名称:"+this.currentThread().getName()+" 开始时间="+System.currentTimeMillis());
Thread.sleep(2000); //延时2秒
System.out.println("正在运行的线程名称:"+this.currentThread().getName()+" 结束时间="+System.currentTimeMillis());
}
catch(InterruptedException e)
{
e.printStackTrace();
}
}
}

  

下面编写主线程的代码,在这里使用 start() 方法来启动 MyThread11 线程。具体代码如下:

package ch14;
public class Test14
{
public static void main(String[] args)
{
MyThread11 mythread=new MyThread11();
System.out.println("主线程开始时间="+System.currentTimeMillis());
mythread.start();
System.out.println("主线程结束时间="+System.currentTimeMillis());
}
}

  

此时运行程序将看到如下所示运行效果。

主线程开始时间=1540964257366
主线程结束时间=1540964257366
正在运行的线程名称:Thread-0 开始时间=1540964257366
正在运行的线程名称:Thread-0 结束时间=1540964259366

  

Java sleep方法的作用(sleep())的更多相关文章

  1. java final方法的作用

    1. 不想让别人修改方法实现. 2. 在方法调用时使用内嵌调用. 3. 有效的“关闭”动态绑定,这样编译器就可以为final方法调用生成更有效的代码. Java编程思想: “然而,大多数情况下,这样做 ...

  2. JAVA 注解的几大作用及使用方法详解

    JAVA 注解的几大作用及使用方法详解 (2013-01-22 15:13:04) 转载▼ 标签: java 注解 杂谈 分类: Java java 注解,从名字上看是注释,解释.但功能却不仅仅是注释 ...

  3. 自己(转)JAVA中toString方法的作用

    JAVA中toString方法的作用 因为它是Object里面已经有了的方法,而所有类都是继承Object,所以“所有对象都有这个方法”. 它通常只是为了方便输出,比如System.out.print ...

  4. 【redis】java操作redis时,StringRedisTemplate的expire()方法的作用,什么时候使用

    java操作redis时,StringRedisTemplate的expire()方法的作用,什么时候使用 //重新设置过期时间为30分钟,刷新时间 redisTemplate.expire(MsOp ...

  5. java克隆对象clone()的使用方法和作用

    转自:997.html">http://www.okrs.cn/blog/news/?997.html 内容摘要 若需改动一个对象,同一时候不想改变调用者的对象.就要制作该对象的一个本 ...

  6. Java中finalize()方法的作用

    finalize方法是Object提供的的实例方法,使用规则如下: 当对象不再被任何对象引用时,GC会调用该对象的finalize()方法 finalize()是Object的方法,子类可以覆盖这个方 ...

  7. JAVA中String类的intern()方法的作用

    一般我们变成很少使用到 intern这个方法,今天我就来解释一下这个方法是干什么的,做什么用的 首先请大家看一个例子: public static void main(String[] args) t ...

  8. 几种任务调度的 Java 实现方法与比较

    综观目前的 Web 应用,多数应用都具备任务调度的功能.本文由浅入深介绍了几种任务调度的 Java 实现方法,包括 Timer,Scheduler, Quartz 以及 JCron Tab,并对其优缺 ...

  9. Java中hashCode的作用

    转  http://blog.csdn.net/fenglibing/article/details/8905007 Java中hashCode的作用 2013-05-09 13:54 64351人阅 ...

随机推荐

  1. CodeForces 718A Efim and Strange Grade (贪心)

    题意:给定一个浮点数,让你在时间 t 内,变成一个最大的数,操作只有把某个小数位进行四舍五入,每秒可进行一次. 析:贪心策略就是从小数点开始找第一个大于等于5的,然后进行四舍五入,完成后再看看是不是还 ...

  2. error: expected ‘)’ before ‘PRId64’(转载)

    转自:www.xuebuyuan.com/2077822.html error: expected ‘)’ before ‘PRId64’ 原来这个宏定义给c用的,C++要用它,就要定义一个__STD ...

  3. 解决Excel打开UTF-8编码CSV文件乱码的问题

    打开 Excel,执行“数据”->“自文本”,选择 CSV 文件,出现文本导入向导,选择“分隔符号”,下一步,勾选“逗号”,去掉“ Tab 键”,下一步,完成,在“导入数据”对话框里,直接点确定 ...

  4. vs code 代码格式化

    1.打开vs code > 文件 > 首选项 > 设置 > 将下面一段粘贴在右侧即可 // Place your settings in this file to overwr ...

  5. TP5之安全机制

    防止sql注入 1.查询条件尽量使用数组方式,具体如下: $wheres = array(); $wheres['account'] = $account; $wheres['password'] = ...

  6. Codeforces 1000 (A~E)

    A Codehorses T-shirts 相同长度之间互相转化即可 #include<iostream> #include<cstdio> #include<cstri ...

  7. 给Clouderamanager集群里安装可视化分析利器工具Hue步骤(图文详解)

    扩展博客 以下,是我在手动的CDH版本,安装Hue. CDH版本大数据集群下搭建Hue(hadoop-2.6.0-cdh5.5.4.gz + hue-3.9.0-cdh5.5.4.tar.gz)(博主 ...

  8. laravel之Storage

    学习laravel一段时间了,从最开始文件保存到本地直到oss都使用原生或接口.今天偶尔看到了Storage.正好项目中有用到就在项目上使用了. 1.下载安装库 composer require ja ...

  9. 转 ORACLE数据库ORA-00392 log 4 of thread 1 is being cleared, operation not allowed错误

    现象: 数据库在做to-time recovery, 时候,restore and recover 都是正常的,但是最后一步open resetlogs 报错如下 ORA-00392 原因: 因为是在 ...

  10. 转 OGG Troubleshooting-Database error 1 (ORA-00001: unique constraint ...)

    Q5: After imp data to target, when we start replc process, we find the following error: 2011-11-10 0 ...