Java中wait和sleep区别

1. Java中wait和sleep区别

  • sleep属于Thread类中的static方法;wait属于Object类的方法
  • sleep时线程状态进入TIMED_WAITING(计时等待),时间到了后自动被唤醒;wait时线程状态进入WAITING(等待),需要手动唤醒
  • sleep方法在线程持有锁时候执行,不会释放锁资源;wait方法执行后会释放锁资源
  • sleep可以在持有锁或者不持有锁时执行;wait方法必须在持有锁时执行
    在这里插入图片描述

2. wait和sleep所属方法的不同

  • sleep属于Thread类中的static方法
public static native void sleep(long millis) throws InterruptedException;

-wait属于Object类中的方法

public final native void wait(long timeout) throws InterruptedException;

3. wait的Demo

Object.wait()必须要写在一个synchronized 同步代码块里面,否则会运行时IllegalMonitorStateException异常
Object.wait()方法后不能自己唤醒,必须等待另外一个线程调用notify()或者notifyAll()才能唤醒
Object.wait()方法会释放锁及cpu资源

3.1 没有synchronized同步代码块异常

wait()/notify()没有写在synchronized同步代码块里面,运行时候会出现IllegalMonitorStateException异常

 public void testMethod1(){
        String lock = new String("lock");
        new Thread(()->{

                System.out.println(Thread.currentThread().getName()+"开始等待时间:"+System.currentTimeMillis());
                try {
                    lock.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread().getName()+"结束等待时间:"+System.currentTimeMillis());

                System.out.println(Thread.currentThread().getName()+"继续往下执行...");

        },"线程A").start();
    }

执行结果:

Exception in thread "线程A" java.lang.IllegalMonitorStateException
	at java.lang.Object.wait(Native Method)
	at java.lang.Object.wait(Object.java:502)
	at com.kevin.base.sync.tx.TestWait.lambda$testMethod1$0(TestWait.java:20)
	at java.lang.Thread.run(Thread.java:748)

3.2 wait使用Demo

public class TestWait {
    public static void main(String[] args) {
        TestWait testWait = new TestWait();
        testWait.testMethod1();

    }

    public void testMethod1(){
        String lock = new String("lock");
        new Thread(()->{
            synchronized (lock){
                System.out.println(Thread.currentThread().getName()+"开始等待时间:"+System.currentTimeMillis());
                try {
                    lock.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread().getName()+"结束等待时间:"+System.currentTimeMillis());

                System.out.println(Thread.currentThread().getName()+"继续往下执行...");
            }
        },"线程A").start();

        new Thread(()->{
            synchronized (lock){
                System.out.println(Thread.currentThread().getName()+"开始唤醒时间:"+System.currentTimeMillis());
                lock.notify();
                System.out.println(Thread.currentThread().getName()+"结束唤醒时间:"+System.currentTimeMillis());

                System.out.println(Thread.currentThread().getName()+"继续往下执行...");
            }
        },"线程B").start();
    }
}

执行结果:

线程A开始等待时间:1678275587083
线程B开始唤醒时间:1678275587083
线程B结束唤醒时间:1678275587083
线程B继续往下执行...
线程A结束等待时间:1678275587083
线程A继续往下执行...

4. sleep的Demo

Thread.sleep()是线程进入睡眠状态,不会释放锁资源,但是会释放cpu资源。这个方法没有强制要求加synchronized同步锁

public class TestSleep {

    public static void main(String[] args) {
        new Thread(()->{
            System.out.println("线程执行....");
            try {
                System.out.println("开始等待时间:"+System.currentTimeMillis());
                Thread.sleep(5000);
                System.out.println("结束等待时间:"+System.currentTimeMillis());
                System.out.println("sleep结束,继续执行");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }).start();
    }
}

执行结果:

线程执行....
开始等待时间:1678276100893
结束等待时间:1678276105893
sleep结束,继续执行
  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值