多线程wait(),notifyAll()唤醒问题

本文探讨了Java多线程中wait(), notifyAll()的使用,通过实例说明这两个方法如何协作唤醒等待的线程。重点指出wait()调用会导致线程释放锁,使得其他线程有机会执行。修正了原示例中对象不一致的问题,提出在构造函数中创建共享对象的解决方案。" 107290615,9823712,C语言经典编程题解析,"['C语言', '算法', '编程实践']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

创建两个Runnable,其中一个的run()方法启动并调用wait(),第二个Runnable中run()方法在一定的几秒之后,为第一个任务调用notify(),从而使得第一个Runnable能显示一条信息,用Executor来测试。

参考例子:点击打开链接     

原博主第一个未改的例子中main线程new了一个RunnableWait对象,但是在RunnableNotify线程类中又new了一个新的对象,所以才会两个obj对象不一样


wait() notify(),notifyAll()三个方法是基于对象的。同时,在wait()等待期间,锁被释放,因此,其它线程得以执行

我修改的

//还有一种不使用静态方法的办法就是在线程任务类中的构造器里构造

class TestRun{}  
  
  
class RunnableWait implements Runnable{  
  
    public static TestRun testRun = new TestRun();//首先加载RunnableWait,生成一个静态实例  
  
      
    @Override  
    public void run() {  
        synchronized (testRun)   
        {  
                System.out.println(Thread.currentThread()+"开始等待" + testRun);  
                try   
                {  
                    testRun.wait();  
                } catch (InterruptedException e) {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                }  
                System.out.println(Thread.currentThread()+"等待结束!" + testRun);  
            }  
    }  
    public static TestRun getLock() //返回对象  
    {  
        return testRun;  
    }  
}  
  
class RunnableNotify implements Runnable{  
  
    private TestRun testRun = RunnableWait.getLock();  
      
    @Override  
    public void run()   
    {  
        synchronized (testRun)  
        {  
            try   
            {  
                TimeUnit.SECONDS.sleep(3);  
            } catch (InterruptedException e) {  
                // TODO Auto-generated catch block  
                e.printStackTrace();  
            }  
            System.out.println(Thread.currentThread()+"唤醒rwait!"+testRun+"/ "+ testRun);  
              
            testRun.notifyAll();  
              
            System.out.println(Thread.currentThread()+"唤醒结束!" + testRun);  
        }  
    }  
}  
  
public class ExecutorMain {  
  
    public static void main(String[] args) {  
    ExecutorService exe =Executors.newCachedThreadPool();  
        exe.execute(new RunnableWait());  
        exe.execute(new RunnableNotify());  
        exe.shutdown();  
    }  
}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值