lock锁

lock锁

三个实现类

可重入锁(普通)ReentrantLock

读锁ReentrantReadWriteLock.ReadLock

写锁ReentrantReadWriteLock.WriteLock

fair和unfair

公平锁:严格执行先来后到

非公平锁:可以插队(默认)

默认非公平锁:如果一个线程需要3h,一个需要执行3s, 如果使用公平锁,不太好

lock三部曲

lock初始化

加锁lock

解锁unlock

代码

package com.example.juc;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class SaleTicket {
    public static void main(String[] args) {
        Ticket ticket = new Ticket();

        new Thread(() -> {
            for (int i = 0; i < 40; i++) {
                ticket.sale();
            }
        }, "A").start();
        new Thread(() -> {
            for (int i = 0; i < 40; i++) {
                ticket.sale();
            }
        }, "B").start();
        new Thread(() -> {
            for (int i = 0; i < 40; i++) {
                ticket.sale();
            }
        }, "C").start();

    }
}

// 资源类 仅包含属性和方法
class Ticket {
    private int num = 20;
    Lock lock = new ReentrantLock();

    public void sale() {
        lock.lock();

        try {
            // 业务代码
            if (num > 0) {
                System.out.println(Thread.currentThread().getName() + "卖出第" + (num--) + "剩余" + num);
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }

    }
}
A卖出第20剩余19
C卖出第19剩余18
C卖出第18剩余17
C卖出第17剩余16
C卖出第16剩余15
C卖出第15剩余14
C卖出第14剩余13
C卖出第13剩余12
C卖出第12剩余11
C卖出第11剩余10
C卖出第10剩余9
C卖出第9剩余8
C卖出第8剩余7
C卖出第7剩余6
C卖出第6剩余5
C卖出第5剩余4
C卖出第4剩余3
C卖出第3剩余2
C卖出第2剩余1
C卖出第1剩余0
上一篇:基于Redis实现分布式锁(二)


下一篇:redis lock 和 tryLock 实际使用区别