当前位置: 首页> 健康> 知识 > 【JUC】09-线程等待与唤醒

【JUC】09-线程等待与唤醒

时间:2025/7/17 23:01:24来源:https://blog.csdn.net/qq_45722630/article/details/141788910 浏览次数:0次

1. Object wait和notify实现等待与唤醒

没有锁会报错。

public class demo01 {public static void main(String[] args) {Object objectLock = new Object();new Thread(()->{synchronized (objectLock) {try {// 释放当前锁, 等待notify, 必须先使用wait才能使用notifyobjectLock.wait();} catch (InterruptedException e) {throw new RuntimeException(e);}System.out.println("Thread 1");}}).start();new Thread(()->{synchronized (objectLock) {System.out.println("Thread 2");objectLock.notify();}}).start();}
}

2. Lock.newCondition await和signal实现等待与唤醒

public class demo02 {public static void main(String[] args) {Lock lock = new ReentrantLock();Condition condition = lock.newCondition();new Thread(()->{lock.lock();try {// 释放锁并等待通知condition.await();System.out.println("Thread 1");} catch (InterruptedException e) {throw new RuntimeException(e);} finally {lock.unlock();}}).start();new Thread(()->{lock.lock();System.out.println("Thread 2");condition.signal();lock.unlock();}).start();}
}

3. LockSupport park和unpark实现等待与唤醒

unpark只能产生一个permit,且可以提前产生,

public class demo03 {public static void main(String[] args) {Thread thread = new Thread(() -> {try {TimeUnit.SECONDS.sleep(2);} catch (InterruptedException e) {throw new RuntimeException(e);}// 可以先进行 unpark, 并且 permit 只能有一个// 需要两个permitLockSupport.park();LockSupport.park();System.out.println("Thread1");});thread.start();new Thread(()->{System.out.println("Thread 2");// 只会产生一个permitLockSupport.unpark(thread);LockSupport.unpark(thread);}).start();}
}
关键字:【JUC】09-线程等待与唤醒

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: