ReentrantLock的使用

 //  用于重启时,保证FillAutoAllotFlowTaskLogQueueThread类中restartInit方法与run方法的执行顺序
    private static final ReentrantLock initLock = new ReentrantLock();


    /**
     * 将工作流自动处理任务线程和填充消费队列线程加入到线程池
     */
    public void autoTaskThreadExecute() {
        try {


            ExecutorService fixedThreadPool = Executors.newFixedThreadPool(THREAD_MAX_NUM);


            askLogQueueThread fillAutoQueueThread = new FlowTaskLogQueueThread();
            initLock.lock();
            try {
                fillAutoQueueThread .restartInit();
            } finally {
                initLock.unlock();
            }


            initLock.lock();
            try {
                fixedThreadPool.execute(fillAutoAllotFlowTaskLogQueueThread);
            } finally {
                initLock.unlock();
            }

        } catch (Exception e) {
            logger.info(e);
        }

    }


//  员工工号对应的锁
    private static ConcurrentHashMap<String, ReentrantLock> staffIdToLock = new ConcurrentHashMap<String, ReentrantLock>();

/**
     * 根据员工工号获取锁
     * @param staffId 工号
     * @return 该员工对应的锁
     */
    private ReentrantLock getLockByStaffId(String staffId) {
        if (!staffIdToLock.containsKey(staffId)) {
            staffIdToLock.put(staffId, new ReentrantLock());
        }
        return staffIdToLock.get(staffId);
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ReentrantLock是Java中的一个可重入锁,它提供了与synchronized关键字类似的功能,但更加灵活和强大。下面是ReentrantLock使用介绍: 1. 创建ReentrantLock对象: ```java ReentrantLock lock = new ReentrantLock(); ``` 2. 获取锁: ```java lock.lock(); // 获取锁,如果锁已被其他线程持有,则当前线程会被阻塞,直到获取到锁为止 ``` 3. 释放锁: ```java lock.unlock(); // 释放锁,如果当前线程持有锁,则释放锁;如果当前线程没有持有锁,则会抛出IllegalMonitorStateException异常 ``` 4. 使用try-finally确保锁的释放: ```java lock.lock(); try { // 执行需要同步的代码块 } finally { lock.unlock(); // 在finally块中释放锁,确保锁的释放 } ``` 5. 使用条件变量: ```java Condition condition = lock.newCondition(); // 创建条件变量 condition.await(); // 当前线程等待,直到其他线程调用signal或signalAll方法唤醒它 condition.signal(); // 唤醒一个等待的线程 condition.signalAll(); // 唤醒所有等待的线程 ``` 6. 公平锁和非公平锁: ReentrantLock可以是公平锁或非公平锁,默认情况下是非公平锁。在构造ReentrantLock对象时,可以传入一个boolean参数来指定是否使用公平锁: ```java ReentrantLock lock = new ReentrantLock(true); // 使用公平锁 ReentrantLock lock = new ReentrantLock(false); // 使用非公平锁 ``` 7. 其他方法: - `isHeldByCurrentThread()`:判断当前线程是否持有锁。 - `getHoldCount()`:获取当前线程持有锁的次数。 - `getQueueLength()`:获取等待获取锁的线程数。 - `hasQueuedThreads()`:判断是否有线程在等待获取锁。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值