package WaitingThread;
public class WaitingThread {
// 锁对象
public static Object object = new Object();
public static void main(String[] args) {
// 匿名内部类
new Thread(new Runnable() {
// 重写
@Override
public void run() {
// 永真循环
while (true) {
// 同步语句块
synchronized (object) {
try {
// 打印
System.out.println(
Thread.currentThread().getName() + "-->获取到锁对象了" + "但是调用了 wait方法,进入到无限等待的方法,释放了锁对象");
// 线程等待
object.wait();
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("从wait状态醒过来,获取到锁对象,并继续执行了");
}
}
}
}, "等待线程").start();
// 给线程一个名字,开启该线程
new Thread(new Runnable() {
@Override
public void run() {
// 设置线程任务
try {
System.out.println(Thread.currentThread().getName() + "--> 休眠3秒");
// 线程停顿了 3秒
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// 唤醒 线程使用的和等待线程的是同一把锁
synchronized (object) {
System.out.println(Thread.currentThread().getName() + "获取到了锁对象,调用 了 notify 方法");
// 唤醒线程
object.notify();
}
}
}, "唤醒线程").start();
}
}
线程的等待与唤醒
最新推荐文章于 2024-08-04 21:20:44 发布
1737

被折叠的 条评论
为什么被折叠?



