Java中wait和sleep区别

文章目录

  • 1. Java中wait和sleep区别
  • 2. wait和sleep所属方法的不同
  • 3. wait的Demo
    • 3.1 没有synchronized同步代码块异常
    • 3.2 wait使用Demo
  • 4. sleep的Demo

1. Java中wait和sleep区别

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

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结束,继续执行

你可能感兴趣的:(java,java)