博客
关于我
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/

你可能感兴趣的文章
MySQL全面瓦解:安装部署与准备
查看>>
mysql共享锁与排他锁
查看>>
MySQL内存表使用技巧
查看>>
MySQL再叙(体系结构、存储引擎、索引、SQL执行过程)
查看>>
mysql出现错误的解决办法
查看>>
MySQL函数
查看>>
mysql函数汇总之字符串函数
查看>>
mysql函数汇总之数学函数
查看>>
mysql函数汇总之日期和时间函数
查看>>
mysql函数汇总之条件判断函数
查看>>
mysql函数汇总之系统信息函数
查看>>
MySQL函数简介
查看>>
mysql函数遍历json数组
查看>>
MySQL函数(转发)
查看>>
mysql分区表
查看>>
MySQL分层架构与运行机制详解
查看>>
mysql分库分表中间件简书_MySQL分库分表
查看>>
MySQL分库分表会带来哪些问题?分库分表问题
查看>>
MySQL分组函数
查看>>
MySQL分组查询
查看>>