• 技术文章 >头条

    聊聊Java ReentrantLock中容易踩到的坑

    小妮浅浅小妮浅浅2021-08-16 19:43:57原创3531


    在finally中释放锁

    使用 ReentrantLock 时一定要记得释放锁,否则就会导致该锁一直被占用,其他使用该锁的线程则会永久的等待下去,所以我们在使用 ReentrantLock 时,一定要在finally中释放锁,这样就可以保证锁一定会被释放。


    反例

    import java.util.concurrent.locks.ReentrantLock;
     
    publicclass LockExample {
        // 创建锁对象
        privatestaticfinal ReentrantLock lock = new ReentrantLock();
        public static void main(String[] args) {
            // 加锁操作
            lock.lock();
            System.out.println("Hello,ReentrantLock.");
            // 此处会报异常,导致锁不能正常释放
            int number = 1 / 0;
            // 释放锁
            lock.unlock();
            System.out.println("锁释放成功!");
        }
    }

    当出现异常时锁未被正常释放,这样就会导致其他使用该锁的线程永久的处于等待状态。


    正例

    import java.util.concurrent.locks.ReentrantLock;
     
    publicclass LockExample {
        // 创建锁对象
        privatestaticfinal ReentrantLock lock = new ReentrantLock();
        public static void main(String[] args) {
            // 加锁操作
            lock.lock();
            try {
                System.out.println("Hello,ReentrantLock.");
                // 此处会报异常
                int number = 1 / 0;
            } finally {
                // 释放锁
                lock.unlock();
                System.out.println("锁释放成功!");
            }
        }
    }

    虽然方法中出现了异常情况,但并不影响 ReentrantLock 锁的释放操作,这样其他使用此锁的线程就可以正常获取并运行了。

    以上就是Java ReentrantLock中容易踩到的坑,希望对大家有所帮助。更多精彩内容分享:头条

    专题推荐:java reentrantlock
    上一篇:Go插件系统Plugin的分析 下一篇:常用6种顶级Python文本编辑器

    相关文章推荐

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网