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

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

Java多线程安全实例:细粒度锁的应用

在多线程编程中,资源共享与竞争可能导致意想不到的行为。为了确保程序的健壮性,我们需要采取适当的同步机制。以下是关于Java多线程安全的一个典型示例。

Account类的同步机制

在本文中,我们创建了一个 Account 类来模拟一个银行账户。该类包含两个成员变量:balance(账户余额)和 password(账户密码)。为了确保这些成员变量的安全访问,我们使用了细粒度锁策略。

资源的保护机制
  • 余额资源的保护

    • 我们使用了一个 final Object 对象 balLock 作为锁。
    • withdraw()getBalance() 方法对 balLock 进行同步,确保在访问账户余额时,其他线程无法进行操作。
    • 这种同步机制保证了余额的安全性,避免了多线程环境下可能导致的竞态条件。
  • 密码资源的保护

    • 同样地,我们使用了一个 final Object 对象 pwLock
    • updatePassword()getPassword() 方法对 pwLock 进行同步,确保密码的修改和查询操作不会互相干扰。
    • 这种设计保证了密码的安全性,防止了未经授权的访问。
  • 代码示例

    以下是 Account 类的完整代码:

    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;        }    }}
    优化与扩展

    在实际应用中,可以根据具体需求对上述代码进行扩展和优化。例如,可以增加密码的验证机制,确保新密码的合法性;或者在 withdraw() 方法中增加参数的校验,防止无效操作。

    总结

    通过使用细粒度锁,我们可以确保不同资源的独立保护。在Java中,使用 synchronized 关键字配合 final Object 实例,可以有效地实现资源的互不干扰。这种方法不仅提高了程序的安全性,还减少了死锁的可能性。

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

    你可能感兴趣的文章
    oracle 切割字符串加引号_使用Clean() 去掉由函数自动生成的字符串中的双引号...
    查看>>
    Oracle 创建 DBLink 的方法
    查看>>
    oracle 创建job
    查看>>
    oracle 创建一个用户,只能访问指定的对象
    查看>>
    oracle 创建双向备份,Materialized View 物化视图实现 Oracle 表双向同步
    查看>>
    oracle 创建字段自增长——两种实现方式汇总
    查看>>
    Oracle 升级10.2.0.5.4 OPatch 报错Patch 12419392 Optional component(s) missing 解决方法
    查看>>
    oracle 去重
    查看>>
    oracle 可传输的表空间:rman
    查看>>
    Oracle 启动监听命令
    查看>>
    Oracle 启动阶段 OPEN
    查看>>
    Oracle 在Drop表时的Cascade Constraints
    查看>>
    Oracle 在Sqlplus 执行sql脚本文件。
    查看>>
    Oracle 如何处理CLOB字段
    查看>>
    oracle 学习
    查看>>
    oracle 定义双重循环例子
    查看>>
    ORACLE 客户端工具连接oracle 12504
    查看>>
    Oracle 客户端连接时报ORA-01019错误总结
    查看>>
    oracle 嵌套表 例子,Oracle之嵌套表(了解)
    查看>>
    Oracle 常用命令
    查看>>