监视器模式示例

监视器模式(Monitor Pattern)是一种并发编程模式,旨在确保对共享资源的访问是线程安全的。它结合了互斥锁(Mutex)和条件变量(Condition Variable)的概念,提供了一种机制来协调多个线程对共享资源的访问。

在监视器模式中,一个共享资源(如数据结构、对象或文件)被封装在一个监视器对象中。该监视器对象控制对共享资源的访问,确保同一时间只有一个线程可以访问资源,从而避免竞态条件(Race Condition)和数据一致性问题。

一个简单的示例来说明监视器模式。假设我们有一个银行账户对象,多个线程可能同时进行存款(deposit)和取款(withdraw)操作,我们希望确保对账户余额的访问是线程安全的。

简单例子

class BankAccount {
  private int balance;
  
  public synchronized void deposit(int amount) {
    balance += amount;
  }
  
  public synchronized void withdraw(int amount) {
    if (balance >= amount) {
      balance -= amount;
    }
  }
}

在上面的代码中,我们使用了Java中的关键字synchronized来实现监视器模式。通过将depositwithdraw方法标记为synchronized,我们确保同一时间只有一个线程可以访问这些方法。这样就避免了多个线程同时对余额进行修改的问题。

当一个线程执行synchronized方法时,它将获取该对象的锁(互斥锁),其他线程必须等待锁的释放才能执行相应的方法。这样就实现了对共享资源的互斥访问。

总结来说,监视器模式是一种并发编程模式,用于确保对共享资源的访问是线程安全的。通过互斥锁和条件变量,它提供了一种机制来协调多个线程对共享资源的访问。通过合理地使用监视器模式,我们可以避免竞态条件和数据一致性问题,保证线程安全性。

稍微复杂例子

class Buffer {
  private int[] buffer;
  private int size;
  private int count;

  public Buffer(int size) {
    this.size = size;
    this.buffer = new int[size];
    this.count = 0;
  }

  public synchronized void produce(int value) throws InterruptedException {
    while (count == size) {
      wait();
    }
    
    buffer[count] = value;
    count++;
    System.out.println("Produced: " + value);

    notifyAll();
  }

  public synchronized int consume() throws InterruptedException {
    while (count == 0) {
      wait();
    }

    int value = buffer[count - 1];
    count--;
    System.out.println("Consumed: " + value);

    notifyAll();

    return value;
  }
}

在上面的代码中,Buffer类表示一个缓冲区,其中的produce方法用于生产数据,consume方法用于消费数据。关键的部分是synchronized关键字和wait()notifyAll()方法的使用。

当缓冲区已满时,生产者线程会调用wait()方法,使自己进入等待状态,直到有空间可供生产。当缓冲区有空间可供消费时,消费者线程会调用notifyAll()方法,唤醒等待中的生产者线程。同样地,当缓冲区为空时,消费者线程会调用wait()方法等待数据的生产。

这个例子展示了如何使用监视器模式实现生产者-消费者问题,通过互斥锁和条件变量来确保生产者和消费者线程之间的同步和互斥访问。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值