文章目录
- 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方法必须在持有锁时执行
  
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结束,继续执行











![[数据结构]:16-归并排序(顺序表指针实现形式)(C语言实现)](https://img-blog.csdnimg.cn/41c9940f80594b03be87a9bb81752916.png)






