博客
关于我
Java并发编程--04 | 互斥锁(下):如何用一把锁保护多个资源?
阅读量:553 次
发布时间:2019-03-09

本文共 901 字,大约阅读时间需要 3 分钟。

一:细粒度锁

相关的示例代码如下,账户类 Account 有两个成员变量,分别是账户余额 balance 和账户密码 password。取款 withdraw() 和查看余额 getBalance() 操作会访问账户余额 balance,我们创建一个 final 对象 balLock 作为锁(类比球赛门票);而更改密码 updatePassword() 和查看密码 getPassword() 操作会修改账户密码 password,我们创建一个 final 对象 pwLock 作为锁(类比电影票)。不同的资源用不同的锁保护,各自管各自的。

class Account {  // 锁:保护账户余额  private final Object balLock    = new Object();  // 账户余额    private Integer balance;  // 锁:保护账户密码  private final Object pwLock    = new Object();  // 账户密码  private String password;  // 取款  void withdraw(Integer amt) {    synchronized(balLock) {      if (this.balance > amt){        this.balance -= amt;      }    }  }   // 查看余额  Integer getBalance() {    synchronized(balLock) {      return balance;    }  }  // 更改密码  void updatePassword(String pw){    synchronized(pwLock) {      this.password = pw;    }  }   // 查看密码  String getPassword() {    synchronized(pwLock) {      return password;    }  }}

 

 

 

 

转载地址:http://elqsz.baihongyu.com/

你可能感兴趣的文章
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>