`

ReentrantLockd的公平锁lock方法实现源码解析

阅读更多

//ReetrantLock公平锁源码解析:
/**公平锁调用的是FairSync中的方法与非公平锁比少了判断当前状态的步骤
 也即非公平锁线程可以在此时直接插队进入执行。
*/
 final void lock() {
            acquire(1);
        }

//和非公平锁的区别是调用了了hasQueuedPredecessors方法判断队列是否为空
  protected final boolean tryAcquire(int acquires) {
            final Thread current = Thread.currentThread();
            int c = getState();
            if (c == 0) {
                if (!hasQueuedPredecessors() &&
                    compareAndSetState(0, acquires)) {
                    setExclusiveOwnerThread(current);
                    return true;
                }
            }
            else if (current == getExclusiveOwnerThread()) {
                int nextc = c + acquires;
                if (nextc < 0)
                    throw new Error("Maximum lock count exceeded");
                setState(nextc);
                return true;
            }
            return false;
        }
    }

/**
当头结点不等于尾节点并且第二个节点是空(当刚初始化头结点但是还没有调用next方法的时候会为空)
或者第二个节点的线程不是当前线程。那么队列不为空。
*/
  public final boolean hasQueuedPredecessors() {
        
        Node t = tail; 
        Node h = head;
        Node s;
        return h != t &&
            ((s = h.next) == null || s.thread != Thread.currentThread());
    }


/**
公平锁也非绝对公平。假如线程A调用tryAcquire失败但是没来得及调用addWaiter方法(还没有入队)
但是此时线程C进来了,发现队列为空那么就直接执行了。

在公平锁中后来的线程都要排队等待,所以比非公平锁效率低。
*/


分享到:
评论

相关推荐

    第五章 ReentrantLock源码解析1--获得非公平锁与公平锁lock()1

    本篇文章将深入解析ReentrantLock的源码,重点讨论非公平锁和公平锁的获取过程。 1. **ReentrantLock的基本概念** ReentrantLock是由Java提供的可重入互斥锁,支持公平锁和非公平锁两种模式。非公平锁的特性是获取...

    公平锁&非公平锁.pdf

    公平锁(Fair Lock)和非公平锁(Non-Fair Lock)是 Java 中的两种锁机制,用于实现线程同步。它们都继承自 AbstractQueuedSynchronizer(AQS),是 ReentrantLock 的基础实现。 公平锁的特点是,它会按照线程的...

    ReentrantLock源码详解--公平锁、非公平锁

    ReentrantLock的lock()方法是通过调用sync属性的lock()方法实现的,sync是公平锁或非公平锁的实例。如果是公平锁,会调用FairSync的lock()方法,否则调用NonfairSync的lock()方法。lock()方法会调用AQS的acquire()...

    基于JDK源码解析Java领域中的并发锁之设计与实现.pdf

    本文将基于JDK源码解析Java领域中的并发锁,探讨AQS基础同步器、LockSupport、Condition接口、Lock接口、ReadWriteLock接口以及自定义API操作的设计与实现。 一、AQS(AbstractQueuedSynchronizer)基础同步器的...

    21 更高级的锁—深入解析Lock.pdf

    **lock方法源码分析** ReentrantLock的lock()方法通过内部的sync对象实现加锁。sync对象是一个抽象类,有两个具体实现:FairSync(公平锁)和NonfairSync(非公平锁)。它们都继承自AbstractQueuedSynchronizer...

    Java并发之ReentrantLock类源码解析

    Java并发之ReentrantLock类源码解析 ReentrantLock是Java并发包中的一种同步工具,它可以实现可重入锁的功能。ReentrantLock类的源码分析对理解Java并发机制非常重要。本文将对ReentrantLock类的源码进行详细分析,...

    易语言源码易语言lock挂机锁源码.rar

    "易语言lock挂机锁源码"是指使用易语言编写的,用于实现挂机锁功能的源代码。挂机锁通常是一种软件保护机制,它可以防止未经授权的用户在无人操作时继续使用计算机或软件,确保软件使用的安全性和合法性。 挂机锁的...

    java的Lock锁原理详解.docx

    // 简化版实现,省略了公平锁和非公平锁的逻辑 while (!tryLock()) { waiters.add(Thread.currentThread()); LockSupport.park(); } } @Override public boolean tryLock() { if (state.get() == 0 && ...

    Java源码解析之可重入锁ReentrantLock

    Java源码解析之可重入锁ReentrantLock ReentrantLock是一个可重入锁,在ConcurrentHashMap中使用了ReentrantLock。它是一个可重入的排他锁,它和synchronized的方法和代码有着相同的行为和语义,但有更多的功能。 ...

    lock锁,lock锁和synchronized的对比

    一种显式定义同步锁对象来实现锁,提供了对共享资源的独占访问,每次只能有一个线程对Lock对象加锁,线程开始访问共享资源之前应先获得Lock锁。 # synchronized锁与lock锁的对比 Lock是显式锁,需要手动的开启和...

    58.Lock-ReentranLock-公平锁与非公平锁.mp4

    在学习Java过程中,自己收集了很多的Java的学习资料,分享给大家,有需要的欢迎下载,希望对大家有用,一起学习,一起进步。

    锁实现lock

    在`lock.cpp`和`lock.h`这两个文件中,`lock.h`可能包含了对外部使用锁的接口声明,而`lock.cpp`则实现了具体的锁操作。例如,一个简单的加锁和解锁操作可以这样定义: 在`lock.h`: ```c #ifndef LOCK_H #define ...

    基于JDK源码解析Java领域中的并发锁,我们需要特别关注哪些内容?

    基于JDK源码解析Java并发锁,我们需要关注以下几个关键知识点: 1. **AQS(AbstractQueuedSynchronizer)基础同步器**: AQS是一个用于构建锁和同步器的框架,它维护了一个FIFO的等待队列,提供了两种模式:独占和...

    jquery实现的九宫格模拟Android屏幕解锁插件patternlock源码.zip

    本篇文章将深入解析jQuery实现的PatternLock插件,帮助你理解和运用这个源码。 一、jQuery基础 jQuery是一个轻量级的JavaScript库,它简化了HTML文档遍历、事件处理、动画和Ajax交互。PatternLock插件正是基于...

    lock4j高性能分布式锁 v2.2.6.zip

    3. 公平性:lock4j支持公平锁,确保等待时间最长的客户端优先获取锁。 4. 可扩展性:lock4j允许用户根据项目需求选择不同的分布式协调服务,如Zookeeper、Redis等。 5. 易用性:简洁的API设计,使开发者能够快速上手...

    多线程(11)ReentrantLock公平锁与非公平锁(修改)1

    // 公平锁 Lock unfairLock = new MyReentrantLock(false); // 非公平锁 List&lt;Worker&gt; workers = new ArrayList(); for (int i = 0; i ; i++) { if (i ) { workers.add(new Worker(fairLock)); } else { workers....

    java 线程公平锁与非公平锁详解及实例代码

    非公平锁是ReentrantLock的默认模式,也是synchronized关键字的实现方式。 在ReentrantLock的内部,公平锁由FairSync类表示,非公平锁由NonfairSync类表示。在NonfairSync中,lock()方法直接尝试通过...

Global site tag (gtag.js) - Google Analytics