java线程与并发编程-同步及低级别的锁

1.给出锁的定义
锁就是实现了接口Lock的实例,它提供了比synchronized保留字更为弹性的锁操作
锁也能通过Condition对象支持等待/通知机制

2.当线程进入临界区(通过synchronized保留字控制),Lock对象与内置锁相比,最大的优势是什么
当线程进入临界区,较之内置锁,Lock对象最大的好处就是具备退出请求锁的能力

3.判断对错:当调用线程没有持有锁,ReentrantLock的unlock()方法会抛出IllegalMonitorStateException

4.如何获取和特定Lock实例一起使用的一个Condition实例
你可以调用Lock的Condition newCondition()方法获取与特定Lock实例相关联的Condition实例

5.判断对错:ReentrantReadWriteLock()创建一个用于公平顺序策略的ReentrantReadWriteLock实例

ReentrantReadWriteLock()创建一个不带有公平顺序策略的ReentrantReadWriteLock实例

6.给出StampedLock定义
JDK8引入的StampedLock是一种基于能力(capability-based)的锁,拥有3种控制读写访问的模式
它类似于ReentrantReadWriteLock的方式区分了互斥和非互斥的锁,还提供了ReentrantReadWriteLock锁不支持的乐观读

7.包java.util.concurrent.locks包含了类LockSupport,这个LockSupport类的意义何在
LockSupport的目的在于为创建锁以及其他同步类提供基本的线程阻塞原语

8.用一个等价类替换下面的ID类,这个类使用ReentrantLock替代了synchronized

public class ID {
    private static int counter;

    public static synchronized int getID() {
        int temp = counter + 1;
        try {
            Thread.sleep(1);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return counter = temp;
    }
}
import java.util.concurrent.locks.ReentrantLock;

public class ID {
    private static int counter;
    private final static ReentrantLock lock = new ReentrantLock();

    public static int getID() {
        lock.lock();
        try {
            int temp = counter + 1;
            try {
                Thread.sleep(1);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return counter = temp;
        } finally {
            lock.unlock();
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值