博客
关于我
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配置信息解读(my.cnf)
查看>>
Mysql配置文件my.ini详解
查看>>
MySQL配置文件深度解析:10个关键参数及优化技巧---强烈要求的福利来咯。
查看>>
Mysql配置表名忽略大小写(SpringBoot连接表时提示不存在,实际是存在的)
查看>>
mysql配置读写分离并在若依框架使用读写分离
查看>>
MySQL里为什么会建议不要使用SELECT *?
查看>>
MySQL里的那些日志们
查看>>
mysql重置root密码
查看>>
MySQL锁
查看>>
MySQL锁与脏读、不可重复读、幻读详解
查看>>
MySQL锁机制
查看>>
mysql锁机制,主从复制
查看>>
Mysql锁机制,行锁表锁
查看>>
MySQL锁表问题排查
查看>>
Mysql锁(1):锁概述和全局锁的介绍
查看>>
Mysql锁(2):表级锁
查看>>
MySQL锁,锁的到底是什么?
查看>>
MySQL错误-this is incompatible with sql_mode=only_full_group_by完美解决方案
查看>>
Mysql错误2003 -Can't connect toMySQL server on 'localhost'(10061)解决办法
查看>>
MySQL错误提示mysql Statement violates GTID consistency
查看>>