ReentrantLock

ReentrantLock 是一个可重入锁。顾名思义它可以被同一个线程重复获取,曾几何时是synchronize代替品
几个重要的方法
  1. lock() :获取锁
  2. lockInterruptibly() :获取锁优先响应中断
  3. tryLock() :尝试获取锁,成功返回true,失败false。该方法不等待立即返回
  4. tryLock(long time,TimeUnit unit) :指定时间内尝试获取锁
  5. unlock() :释放锁
公平锁,缺点需要维护一个队列,因此成本高,性能低下,一般情况锁是非公平的
 public ReentrantLock(boolean fair) //当fair为true时,表是锁是公平的

使用公平锁线程获取是有序的,如果不使用则同一条线程会有重复获取2以上的情况
Thread-1:获取锁成功
Thread-0:获取锁成功
Thread-1:获取锁成功
Thread-0:获取锁成功

搭档Condition 它与Object.wait和Object.notify类似
  1. await()= Object.wait
  2. singal()=Object.notify
public class ReentrantLockDemo3 implements Runnable {

    private static ReentrantLock lock=new ReentrantLock();
    private static Condition c=lock.newCondition();

    @Override
    public void run() {
        try {
            lock.lock();
            c.await();
            System.out.println("!!!!!");

        } catch (Exception e) {
            e.printStackTrace();
        }finally {
            if(lock.isHeldByCurrentThread()){
                lock.unlock();
            }

            System.out.println(Thread.currentThread().getName()+":线程退出");
        }

    }

    public static void main(String[] args) throws InterruptedException {
            ReentrantLockDemo3 r1 = new ReentrantLockDemo3();
            Thread thread = new Thread(r1);
            thread.start();
            Thread.sleep(5000);
            //需要注意的是想要用Condition的api必须先活得锁
            lock.lock();
            c.signal();
            //只有释放后其他线程才能重新获取锁,并继续运行
            lock.unlock();


    }



}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值