博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java语言当中-sleep()和await()的差异
阅读量:4291 次
发布时间:2019-05-27

本文共 2541 字,大约阅读时间需要 8 分钟。

这里需要提一下,语言的底层的东西,是非常值得去推荐的。

原文链接:(感谢作者)

原来我已经简单说明过两者的作用:

对于sleep()方法,我们首先要知道该方法是属于Thread类中的。而wait()方法,则是属于Object类中的。

sleep()方法导致了程序暂停执行指定的时间,让出cpu该其他线程,但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。

在调用sleep()方法的过程中,线程不会释放对象锁。

而当调用wait()方法的时候,线程会放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象调用notify()方法后本线程才进入对象锁定池准备

获取对象锁进入运行状态。

什么意思呢?

举个列子说明:

/** * java中的sleep()和wait()的区别 * @author Hongten * @date 2013-12-10 */public class TestD {    public static void main(String[] args) {        new Thread(new Thread1()).start();        try {            Thread.sleep(5000);        } catch (Exception e) {            e.printStackTrace();        }        new Thread(new Thread2()).start();    }        private static class Thread1 implements Runnable{        @Override        public void run(){            synchronized (TestD.class) {            System.out.println("enter thread1...");                System.out.println("thread1 is waiting...");            try {                //调用wait()方法,线程会放弃对象锁,进入等待此对象的等待锁定池                TestD.class.wait();            } catch (Exception e) {                e.printStackTrace();            }            System.out.println("thread1 is going on ....");            System.out.println("thread1 is over!!!");            }        }    }        private static class Thread2 implements Runnable{        @Override        public void run(){            synchronized (TestD.class) {                System.out.println("enter thread2....");                System.out.println("thread2 is sleep....");                //只有针对此对象调用notify()方法后本线程才进入对象锁定池准备获取对象锁进入运行状态。                TestD.class.notify();                //==================                //区别                //如果我们把代码:TestD.class.notify();给注释掉,即TestD.class调用了wait()方法,但是没有调用notify()                //方法,则线程永远处于挂起状态。                try {                    //sleep()方法导致了程序暂停执行指定的时间,让出cpu该其他线程,                    //但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。                    //在调用sleep()方法的过程中,线程不会释放对象锁。                    Thread.sleep(5000);                } catch (Exception e) {                    e.printStackTrace();                }                System.out.println("thread2 is going on....");                System.out.println("thread2 is over!!!");            }        }    }}

运行效果:

enter thread1...thread1 is waiting...enter thread2....thread2 is sleep....thread2 is going on....thread2 is over!!!thread1 is going on ....thread1 is over!!!

如果注释掉代码:

1 TestD.class.notify();

enter thread1...thread1 is waiting...enter thread2....thread2 is sleep....thread2 is going on....thread2 is over!!!

转载地址:http://acegi.baihongyu.com/

你可能感兴趣的文章
视音频数据处理入门:H.264视频码流解析
查看>>
视音频数据处理入门:AAC音频码流解析
查看>>
视音频数据处理入门:UDP-RTP协议解析
查看>>
视音频数据处理入门:FLV封装格式解析
查看>>
最简单的基于FFMPEG的封装格式转换器(无编解码)
查看>>
base64 编码原理
查看>>
单链表是否有环的问题
查看>>
判断两个链表是否相交并找出交点
查看>>
归并排序
查看>>
STL常见问题
查看>>
time_wait和close_wait状态
查看>>
STL中vector、list、deque和map的区别
查看>>
Linux下多线程查看工具(pstree、ps、pstack)
查看>>
PID PPID LWP NLWP
查看>>
查看线程CPU占用情况
查看>>
查看个线程的CPU 内存占用
查看>>
svn中设置文件夹链接
查看>>
find ./ -name "*.cgi" |xargs -i cp "{}" ./cgi-bin/
查看>>
svn st | awk '{if ( $1 == "?") { print $2}}' | xargs svn add
查看>>
mysql事务处理用法与实例详解
查看>>