java中的sleep()、wait()、notify()的区别

1.调用wait()方法,线程会放弃对象锁,进入等待此对象的等待锁定池

2.sleep()方法导致了程序暂停执行指定的时间,让出cpu该其他线程, 但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。 在调用sleep()方法的过程中,线程不会释放对象锁。

3.只有针对锁对象调用notify()方法后wait线程才进入对象锁定池准备获取对象锁进入运行状态。

public class YslLock {

    private static Object object = new Object();
    public static void main(String[] args) {
        testThread();
    }

    private static void testThread() {
        new Thread(new Runnable() {
            @Override
            public void run() {
                synchronized (object) {
                    System.out.println("enter thread1...");
                    System.out.println("thread1 is waiting...");
                    try {
                        //调用wait()方法,线程会放弃对象锁,进入等待此对象的等待锁定池
                        object.wait();
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                    System.out.println("thread1 is going on ....");
                    System.out.println("thread1 is over!!!");
                }
            }
        }).start();
        try {
            Thread.sleep(5000);
        } catch (Exception e) {
            e.printStackTrace();
        }
        new Thread(new Runnable() {
            @Override
            public void run() {
                synchronized (object) {
                    System.out.println("enter thread2....");
                    System.out.println("thread2 is sleep....");
                    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!!!");
                    //只有针对锁对象调用notify()方法后wait线程才进入对象锁定池准备获取对象锁进入运行状态。
                    object.notify();
                }

            }
        }).start();
    }

}

运行结果:

可以看到wait之后,第一个线程停止运行,开始运行第二个线程。当sleep时,第二个线程也停止运行了。当结束sleep,第二个线程继续运行,到结尾调用了对象锁的notify方法。然后wait的线程又开始继续运行。正好证明了上面写的三句话。

亲测:在第二个线程中,把object.notify();挪到run方法的第一行。结果也是一样的。这就说明:当持有对象锁的线程只有运行完成之后,notify才会真正的起作用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值