【Java并发编程的艺术学习】第五章摘要补全

发布时间:2024年01月17日

1.finally作用:

担心一些资源可能无法正常释放,使用finally释放资源

2.ReentrainLock

释放死锁,使用这个接口,这样就不会产生死锁

Lock lock=new ReentrainLock();
lock.lock();
try{
}finally{
    lock.unlock();
}

3.重入锁

支持重新进入的锁,表示该锁能够支持一个线程对资源的重复加锁。除此之外,该锁还支持获取锁时的公平和非公平性选择。

在类似于递归等反复调用的场景中使用

4.读写锁

只适用于读多写少的场景

特性说明
公平性选择支持非公平和公平的锁获取方式,吞吐量还是非公平优先于公平
重进入支持重进入,以读写线程为例:该线程在获取了读锁以后,能够再次获取读锁。而写线程在获取了写锁之后能够再次获取写锁,同时也可以获取读锁
锁降级遵循获取写锁,获取读锁再次释放写锁的次序,写锁能够降级成为读锁

5.手写一个cache缓存

//设置key对应的value,并返回旧的value
public static final Object put(String key,Object value){
    w.lock();
    try{
        return map.put(key,value);
    }finally{
        w.unlock();
    }
} 
//清空所有内容
public static final void clear(){
    w.lock();
    try{
        map.clear();
    }finally{
        w.unclock();
    }
}

6.锁降级的过程中不会释放锁

7.调用Condition的await()方法(或者以await开头的方法)会使当前线程进入等待队列并释放锁,同时线程状态变为等待状态。当从await()方法返回时,当前线程一定获取了Condition相关的锁

文章来源:https://blog.csdn.net/weixin_62647396/article/details/135651722
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。