博客
关于我
java线程(17)——Lock锁,三个线程抢票加上lock锁后变成三个线程排队买票
阅读量:322 次
发布时间:2019-03-04

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

多线程抢票问题及Lock锁的应用

1. 线程抢票问题

传统的多线程票务系统可能会出现线程安全问题,尤其是在多个线程同时操作共享资源时。例如,三个线程同时抢票可能导致票数重复售出或票数异常减少等问题。

不安全的代码示例

public class TestLock {    public static void main(String[] args) {        TestLock2 testLock2 = new TestLock2();        new Thread(testLock2).start();        new Thread(testLock2).start();        new Thread(testLock2).start();    }}class TestLock2 implements Runnable {    int ticketNums = 10;        @Override    public void run() {        while (true) {            if (ticketNums > 0) {                Thread.sleep(1000);                System.out.println(ticketNums--);            } else {                break;            }        }    }}

运行结果示例

运行时可能会出现以下问题:

  • 同一个票可能被多个线程同时抢购
  • 票数可能会异常减少
  • 2. 使用Lock锁解决问题

    通过引入ReentrantLock锁,可以有效防止线程抢票问题。以下是改进后的代码:

    import java.util.concurrent.locks.ReentrantLock;public class TestLock {    public static void main(String[] args) {        TestLock2 testLock2 = new TestLock2();        new Thread(testLock2).start();        new Thread(testLock2).start();        new Thread(testLock2).start();    }}class TestLock2 implements Runnable {    int ticketNums = 10;    private final ReentrantLock lock = new ReentrantLock();    @Override    public void run() {        while (true) {            lock.lock();            try {                if (ticketNums > 0) {                    Thread.sleep(1000);                    System.out.println(ticketNums--);                } else {                    break;                }            } finally {                lock.unlock();            }        }    }}

    改进后的运行结果

  • 每个线程将独占性地持有锁,确保票数正确递减
  • 票数将按顺序递减,避免重复售出
  • 系统运行更加稳定,线程安全得到了有效保障
  • 3. Lock锁与synchronized的对比

    主要区别

  • 锁的类型

    • Lock锁是显示锁,需要手动开启和关闭锁
    • synchronized是隐式锁,自动释放锁定状态
  • 锁的应用场景

    • Lock锁提供更细粒度的锁控制,可以灵活配置锁定区域
    • synchronized的锁定范围更大,通常用于方法或代码块层面的资源保护
  • 性能特点

    • Lock锁的锁解锁操作由用户手动控制,JVM调度线程时更高效
    • synchronized的锁解锁操作由JVM自动处理,性能相对较低
  • 选择建议

    在多线程环境下,建议根据具体需求选择合适的锁机制:

    • 如果需要细粒度的资源控制,Lock锁是一个更好的选择
    • 如果需要快速实现线程安全,synchronized提供了一个简洁的解决方案

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

    你可能感兴趣的文章
    openssl内存分配,查看内存泄露
    查看>>
    OpenSSL创建SSL证书
    查看>>
    openssl在cygwin下编译错误:CPU不支持x86_64(CPU you selected does not support x86-64 instruction set )
    查看>>
    openssl安装
    查看>>
    openssl安装
    查看>>
    OpenSSL生成root CA及签发证书
    查看>>
    Openstack CLI命令管理私有云主机实战(附OpenStack实验环境)
    查看>>
    openStack instance error 恢复
    查看>>
    openstack instance resize to
    查看>>
    openstack message queue
    查看>>
    openstack network:dhcp binding fail
    查看>>
    openStack openSource CloudComputing
    查看>>
    Openstack REST API
    查看>>
    OpenStack ussuri 私有云平台搭建企业级实战
    查看>>
    OpenStack 上部署 Kubernetes 方案对比
    查看>>
    Openstack 之 网络设置静态IP地址
    查看>>
    openstack 创建虚拟机的时候报错: Failed to allocate the network(s), not rescheduling.].
    查看>>
    OpenStack 存储服务详解
    查看>>
    openstack 导出镜像
    查看>>
    OpenStack 搭建私有云主机实战(附OpenStack实验环境)
    查看>>