java架构《并发线程高级篇四》

Posted 一只奋斗中的小菜鸡

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java架构《并发线程高级篇四》相关的知识,希望对你有一定的参考价值。

    本章主要讲并发线程的常见的两种锁。重入锁和读写锁

 

一:重入锁(ReentrantLock)

    概念:重入锁,在需要进行同步的代码加锁,但最后一定不要忘记释放锁,否则会造成锁永远不能释放,其他线程进不了

    代码解析:

        实例化:Lock lock = new ReentrantLock();

        锁定:lock .lock();

        释放锁:lock.unlock();

 

    代码:

        

      private Lock lock = new ReentrantLock();

      public void method1(){
          try {
            lock.lock();
            System.out.println("当前线程:" + Thread.currentThread().getName() + "进入method1..");
            Thread.sleep(1000);
            System.out.println("当前线程:" + Thread.currentThread().getName() + "退出method1..");
            Thread.sleep(1000);
            } catch (InterruptedException e) {
              e.printStackTrace();
            } finally {

            lock.unlock();
          }
        }

 

    Condition类:配合重入锁,阻塞和通知,不需要配合synchronized使用,比较灵活,支持多个线程锁定,同时通知全部。

          阻塞和通知:

          private Lock lock = new ReentrantLock();

          private Condition condition = lock.newCondition();

          阻塞:condition.await();    

          通知:condition.signal(); 

           通知全部:condition.signalall()

   Lock/Condition其他方法和用法:

        Lock lock=new  ReentrantLock(boolean isFair);

            tryLock():尝试获得锁,返回false/true

            tryLock():在给定的时间内尝试获得锁,获得结果用 true/false表示。

            isFair():返回是否是公平锁  true/false

            isLocked():返回是否锁定

            getHoldCount():返回当前线程保持此锁的个数,或者说表示调用了lock()的次数

            lockinterruptibly():优先响应中断的锁

            getQueueLength():返回正在等待获取此锁定的线程数。 

            getWaitQueueLength():返回等待与锁定相关的给定条件Condition的线程数

            hasQueueThread(Thread t):查询指定的线程是否正在等待此锁

            hasQueueThreads():查询是否有线程正在等待此锁

            hasWaiters():查询是否有线程正在等待与此锁定有关的condition条件

 

 

二:读写锁(ReentrantReadWriteLock)

     概念:其核心就是读写分离的锁,在读多写少情况下,性能远高于重入锁 。口诀:读读共享,写写互斥,读写互斥

     代码解析:

        实例化:       

          private ReentrantReadWriteLock rwLock = new ReentrantReadWriteLock();
          private ReadLock readLock = rwLock.readLock();  //获取到读锁
          private WriteLock writeLock = rwLock.writeLock();  //获取到写锁

 

 

        

    


















以上是关于java架构《并发线程高级篇四》的主要内容,如果未能解决你的问题,请参考以下文章

互联网架构多线程并发编程高级教程(上)

互联网架构多线程并发编程高级教程(下)

蚂蚁JAVA互联网高级架构师第3期视频教程

多线程必看之JAVA线程并发辅助类

Java多线程与并发库高级应用-java5线程并发库

Java并发编程:死锁(含代码)